Codacy PMD Java 镜像是 Codacy 平台集成 PMD (Programming Mistake Detector) 工具的 Docker 镜像,专为 Java 代码的静态分析设计。该镜像封装了 PMD 静态代码分析引擎,旨在自动化检测 Java 代码中的常见编程问题(如未使用变量、空指针风险、低效代码等),并与 Codacy 代码质量平台无缝集成。
docker run 命令)4.1.1 本地代码分析
通过挂载代码目录并指定规则集,输出分析结果到本地文件:
bashdocker run --rm \ -v /本地代码目录:/app/code \ # 挂载待分析代码目录 -v /本地规则集目录:/app/rules \ # 挂载自定义规则集(可选) -e CODACY_PMD_RULESET=/app/rules/custom.xml \ # 指定规则集路径(默认使用内置规则) -e OUTPUT_FORMAT=json \ # 输出格式:json/xml(默认json) -e JAVA_VERSION=11 \ # 目标代码的 Java 版本(默认8) codacy/codacy-pmdjava:latest \ # 镜像名称(需替换为实际标签) /app/code # 待分析代码目录路径(容器内路径)
4.1.2 输出结果
分析结果默认输出到容器内 /app/result.json(或指定格式文件),可通过挂载目录持久化:
bashdocker run --rm \ -v /本地代码目录:/app/code \ -v /本地结果目录:/app/result \ # 挂载结果目录 -e OUTPUT_PATH=/app/result/report.json \ # 自定义结果文件路径 codacy/codacy-pmdjava:latest \ /app/code
通过 docker-compose.yml 定义服务,适用于多环境复用:
yamlversion: '3' services: codacy-pmdjava: image: codacy/codacy-pmdjava:latest volumes: - ./src:/app/code # 本地代码目录映射到容器内 /app/code - ./pmd-rules:/app/rules # 本地规则集目录映射(可选) - ./reports:/app/result # 结果输出目录映射 environment: - CODACY_PMD_RULESET=/app/rules/company-rules.xml # 自定义规则集 - JAVA_VERSION=17 # 目标代码 Java 版本 - OUTPUT_FORMAT=xml # 输出 XML 格式便于集成到其他工具 - OUTPUT_PATH=/app/result/pmd-report.xml # 结果文件路径 command: /app/code # 待分析代码的容器内路径
启动命令:
bashdocker-compose up
| 参数名 | 描述 | 默认值 | 示例值 |
|---|---|---|---|
CODACY_PMD_RULESET | PMD 规则集文件路径(容器内) | /app/default-rules.xml | /app/rules/custom-rules.xml |
JAVA_VERSION | 目标代码的 Java 版本 | 8 | 11, 17 |
OUTPUT_FORMAT | 分析结果格式 | json | xml, json |
OUTPUT_PATH | 结果文件输出路径(容器内) | /app/result.json | /app/report/pmd-results.xml |
DEBUG | 是否启用调试模式(输出详细日志) | false | true |
codacy)有读/写权限,避免因权限不足导致文件访问失败JAVA_VERSION 需与待分析代码的编译版本匹配,否则可能出现语法解析错误OUTPUT_FORMAT,镜像会自动适配平台要求的格式您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务