
本Docker镜像专为Jenkins CI/CD流水线设计,提供标准化的编译构建环境。通过整合主流开发语言的构建工具与运行时依赖,确保跨项目、跨环境的构建一致性,解决"环境差异导致构建失败"的常见问题,简化Jenkins流水线配置,提升自动化构建效率与可靠性。
agent { docker { image 'jenkins-compiler-pipeline:latest' } }直接调用4.1.1 拉取镜像
bashdocker pull jenkins-compiler-pipeline:latest
4.1.2 执行本地构建(以Maven项目为例)
bash# 挂载当前项目目录到容器/app,执行mvn打包 docker run --rm \ -v $(pwd):/app \ -w /app \ jenkins-compiler-pipeline:latest \ mvn clean package -DskipTests
4.2.1 Jenkins系统配置
compiler-agentjenkins-compiler-pipeline:latest/home/jenkinscompiler pipeline maven gradle node4.2.2 Jenkinsfile示例(Pipeline语法)
groovypipeline { agent { docker { image 'jenkins-compiler-pipeline:latest' reuseNode true } } stages { stage('Build') { steps { sh 'npm install' // 前端项目依赖安装 sh 'npm run build' // 前端构建 sh 'mvn clean package' // 后端项目打包 } } stage('Test') { steps { sh 'mvn test' // 运行单元测试 } } } post { success { archiveArtifacts artifacts: 'target/*.jar', fingerprint: true } } }
yamlversion: '3.8' services: jenkins: image: jenkins/jenkins:lts ports: - "8080:8080" volumes: - jenkins_home:/var/jenkins_home - /var/run/docker.sock:/var/run/docker.sock environment: - JAVA_OPTS=-Djenkins.install.runSetupWizard=false compiler-agent: image: jenkins-compiler-pipeline:latest volumes: - maven_cache:/root/.m2 - npm_cache:/root/.npm command: sleep infinity # 保持容器运行供Jenkins连接 volumes: jenkins_home: maven_cache: # Maven本地仓库缓存 npm_cache: # npm缓存
| 环境变量名 | 描述 | 默认值 |
|---|---|---|
MAVEN_OPTS | Maven运行时参数 | -Xmx1024m -XX:MaxPermSize=256m |
GRADLE_OPTS | Gradle运行时参数 | -Xmx1024m |
HTTP_PROXY | 全局HTTP代理 | 无 |
HTTPS_PROXY | 全局HTTPS代理 | 无 |
NO_PROXY | 不使用代理的域名列表 | localhost,127.0.0.1 |
BUILD_CACHE_DIR | 构建缓存根目录 | /root/.cache |
如需使用特定版本的构建工具,可通过Dockerfile二次构建:
dockerfileFROM jenkins-compiler-pipeline:latest # 安装特定版本Maven RUN apk add --no-cache wget \ && wget https://archive.apache.org/dist/maven/maven-3/3.8.8/binaries/apache-maven-3.8.8-bin.tar.gz -P /tmp \ && tar -zxvf /tmp/apache-maven-3.8.8-bin.tar.gz -C /usr/local \ && ln -sf /usr/local/apache-maven-3.8.8/bin/mvn /usr/local/bin/mvn \ && rm -rf /tmp/*
-v $HOME/.m2:/root/.m2):1.2.0)而非:latest,确保构建稳定性root用户运行,生产环境可通过--user参数指定非特权用户您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 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 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务