我正在使用Docker创建Sonarqube环境,但是当我运行扫描程序时,发生了错误。
我将扫描仪直接运行到容器中:
PS C:\docker\sonarqube\projects\test> docker exec -it sonarqube /bin/bash
sonarqube@05399e4fa8a6:/home/projects/test$ sonar-scanner
INFO:扫描仪配置文件:/usr/lib/sonar-scanner/conf/sonar-scanner.properties
INFO:项目根配置文件:/home/projects/test/sonar-project.properties
INFO:SonarQube Scanner 4.2.0.1873
INFO: Java 11.0.3 AdoptOpenJDK(64位)
INFO:Linux 4.9.184-linuxkit amd64
INFO:----------------------------- -------------------------------------------
INFO:执行失败
INFO:- -------------------------------------------------- ---------------------
INFO:总时间:0.364s
INFO:最终内存:2M / 10M
INFO:------------ -------------------------------------------------- ----------
错误:SonarQube Scanner执行期间出错
java.lang.IllegalStateException:无法创建用户缓存:
org.sonarsource.scanner.api.internal.cache.FileCache.createDir(FileCache.java:147)
上的/home/.sonar/cache在org.sonarsource.scanner.api上org.sonarsource.scanner.api.internal.cache.FileCache.create(FileCache.java:52)
的org.sonarsource.scanner.api.internal.cache的.internal.cache.FileCache。(FileCache.java:46)
。
org.sonarsource.scanner.api.internal.JarDownloaderFactory.create(JarDownloaderFactory.java:42)的FileCacheBuilder.build(FileCacheBuilder.java:48)
org.sonarsource.scanner.api.internal.IsolatedLauncherFactory.createLauncher(IsolatedLauncherFactory.java: 68)
在org.sonarsource.scanner.api.EmbeddedScanner.doStart(EmbeddedScanner.java:185)
在org.sonarsource.scanner.api.EmbeddedScanner.start(EmbeddedScanner.java:123)
在org.sonarsource.scanner.cli.Main.execute (Main.java:73)
在org.sonarsource.scanner.cli.Main.main(Main.java:61)
导致原因:java.nio.file.AccessDeniedException:/home/.sonar/cache
在java.base / sun .nio.fs.UnixException.translateToIOException(未知来源)
在java.base / sun.nio.fs.UnixException.rethrowAsIOException(未知来源)
在java.base / sun.nio.fs.UnixException.rethrowAsIOException(未知来源)
在java的.base / sun.nio.fs.UnixFileSystemProvider.createDirectory(未知源)
在java.base / java.nio.file.Files.createDirectory(未知来源)
在java.base / java.nio.file.Files.createAndCheckIsDirectory(未知来源)
在java.base / java.nio.file.Files.createDirectories
org.sonarsource.scanner.api.internal.cache.FileCache.createDir(FileCache.java:145)上的(未知源)
...还有9个
这是我在docker-compose中使用的dockerfile:
FROM sonarqube:latest
# Switch to root user to be able to install packages.
USER root
# Install packages.
RUN apt-get update
RUN apt-get install -y vim wget
# Install sonarqube scanner.
WORKDIR /usr/src
RUN wget https://binaries.sonarsource.com/Distribution/sonar-scanner-cli/sonar-scanner-cli-4.2.0.1873-linux.zip
RUN unzip sonar-scanner-cli-4.2.0.1873-linux.zip
RUN rm sonar-scanner-cli-4.2.0.1873-linux.zip
RUN mv sonar-scanner-4.2.0.1873-linux /usr/lib/sonar-scanner
# Create symbolic link.
RUN ln -s /usr/lib/sonar-scanner/bin/sonar-scanner /usr/local/bin/sonar-scanner
ENV SONAR_RUNNER_HOME=/usr/lib/sonar-scanner
ENV SONAR_USER_HOME=/home/.sonar
# Switch back to the sonarqube environment.
WORKDIR $SONARQUBE_HOME
USER sonarqube
码头工人组成:
version: '3.7'
services:
sonarqube:
build: .
container_name: sonarqube
ports:
- 9000:9000
networks:
- sonarnet
environment:
- sonar.jdbc.url=jdbc:postgresql://db:5432/sonar
volumes:
- ./projects:/home/projects
- sonarqube_conf:/opt/sonarqube/conf
- sonarqube_data:/opt/sonarqube/data
- sonarqube_logs:/opt/sonarqube/logs
- sonarqube_extensions:/opt/sonarqube/extensions
db:
image: postgres:latest
container_name: sonarqube_database
networks:
- sonarnet
environment:
- POSTGRES_USER=sonar
- POSTGRES_PASSWORD=sonar
volumes:
- postgresql:/var/lib/postgresql
- postgresql_data:/var/lib/postgresql/data
networks:
sonarnet:
driver: bridge
volumes:
projects:
sonarqube_conf:
sonarqube_data:
sonarqube_logs:
sonarqube_extensions:
postgresql:
postgresql_data:
我知道这是访问问题,但我不明白为什么。
任何想法为什么会这样?
解决了我的问题。在dockerfile中:
RUN mkdir /home/.sonar
RUN chmod 777 /home/.sonar
ENV SONAR_USER_HOME=/home/.sonar
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句