govpf/sonar-scannerDocker Sonar Scanner 镜像是基于 Sonar Scanner 工具构建的容器化解决方案,集成了代码质量分析所需的运行环境及依赖,可直接在容器中执行代码扫描任务,无需在本地或服务器手动安装 Sonar Scanner。
用于对源代码进行自动化质量检测与安全分析,支持将扫描结果上传至 SonarQube 服务器进行集中展示、报告生成及问题追踪,帮助开发团队持续监控代码质量、发现潜在缺陷(如 bug、漏洞、代码异味等)并优化代码规范。
扫描任务需通过环境变量指定核心参数,常用变量如下:
| 环境变量名 | 说明 | 是否必填 |
|---|---|---|
SONAR_HOST_URL | SonarQube 服务器地址(如 [***]) | 是 |
SONAR_TOKEN | SonarQube 访问令牌(在 SonarQube 控制台创建,用于认证) | 是 |
SONAR_PROJECT_KEY | 项目唯一标识(在 SonarQube 中预先创建或自动生成) | 是 |
SONAR_PROJECT_NAME | 项目名称(用于 SonarQube 界面展示,可选,默认与 SONAR_PROJECT_KEY 一致) | 否 |
SONAR_PROJECT_VERSION | 项目版本(如 1.0.0,可选) | 否 |
SONAR_SCANNER_OPTS | 扫描器 JVM 参数(如 -Xmx512m,用于调整内存限制,可选) | 否 |
docker run 命令)通过 docker run 直接启动容器,挂载本地代码目录并指定环境变量:
bashdocker run --rm \ -e SONAR_HOST_URL="[***]" \ -e SONAR_TOKEN="your-sonarqube-token" \ -e SONAR_PROJECT_KEY="my-project-key" \ -v /path/to/local/code:/app \ # 挂载本地代码目录到容器内 /app(扫描目标目录) sonar-scanner:latest \ -Dsonar.sources=/app \ # 指定容器内待扫描代码路径(需与挂载路径对应) -Dsonar.java.binaries=/app/target/classes # (Java 项目可选)指定编译后的 class 文件路径
说明:
/path/to/local/code需替换为本地源代码根目录的绝对路径;- 额外扫描参数(如排除目录、自定义规则集)可通过
-D参数名=值形式追加(参考 Sonar Scanner 官方参数文档)。
若需与 SonarQube 服务器联动部署(如本地测试环境),可通过 docker-compose.yml 定义多容器服务:
yamlversion: '3.8' services: # SonarQube 服务器(若已独立部署,可删除此服务) sonarqube: image: sonarqube:latest ports: - "9000:9000" environment: - SONAR_ES_BOOTSTRAP_CHECKS_DISABLE=true volumes: - sonarqube_data:/opt/sonarqube/data - sonarqube_extensions:/opt/sonarqube/extensions networks: - sonar-network # Sonar Scanner 服务(执行扫描任务) sonar-scanner: image: sonar-scanner:latest depends_on: - sonarqube environment: - SONAR_HOST_URL=[***] # 连接同一网络中的 SonarQube 服务 - SONAR_TOKEN=your-sonarqube-token - SONAR_PROJECT_KEY=my-project-key - SONAR_PROJECT_NAME=My Application - SONAR_PROJECT_VERSION=1.0.0 volumes: - /path/to/local/code:/app # 挂载本地代码到容器内 /app command: -Dsonar.sources=/app -Dsonar.exclusions=**/node_modules/** # 排除 node_modules 目录 networks: - sonar-network networks: sonar-network: driver: bridge volumes: sonarqube_data: sonarqube_extensions:
启动命令:
bashdocker-compose up sonar-scanner # 仅启动扫描服务(依赖 SonarQube 服务)
sonar-project.properties)若扫描参数较多,可在代码根目录创建 sonar-project.properties 配置文件,容器启动时自动读取:
properties# sonar-project.properties(放置于 /path/to/local/code 目录下) sonar.projectKey=my-project-key sonar.projectName=My Application sonar.projectVersion=1.0.0 sonar.sources=. # 相对路径(容器内代码目录,即 /app) sonar.host.url=[***] sonar.login=your-sonarqube-token # 也可通过环境变量 SONAR_TOKEN 传入,优先级更高 sonar.exclusions=**/*.test.js,**/vendor/** # 排除测试文件及第三方依赖 sonar.javascript.eslint.reportPaths=eslint-report.json # 集成 ESLint 报告(可选)
使用配置文件启动容器:
bashdocker run --rm \ -v /path/to/local/code:/app \ # 配置文件需在此目录下 sonar-scanner:latest
chmod -R 755 /path/to/local/code 调整)。SONAR_HOST_URL 指向的 SonarQube 服务器(若使用 Docker Compose,需确保服务在同一网络内)。SONAR_SCANNER_OPTS="-Xmx1024m" 增加 JVM 内存。探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
在 Linux 系统配置镜像服务
在 Docker Desktop 配置镜像
Docker Compose 项目配置
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
MacOS OrbStack 容器配置
在宝塔面板一键配置镜像
Synology 群晖 NAS 配置
飞牛 fnOS 系统配置镜像
极空间 NAS 系统配置服务
爱快 iKuai 路由系统配置
绿联 NAS 系统配置镜像
QNAP 威联通 NAS 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
无需登录使用专属域名
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
免费版仅支持 Docker Hub 访问,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等;免费版仅支持 docker.io。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
来自真实用户的反馈,见证轩辕镜像的优质服务