JPom结合Docker实现SpringBoot项目自动化构建与部署实战

张开发
2026/4/20 6:56:46 15 分钟阅读

分享文章

JPom结合Docker实现SpringBoot项目自动化构建与部署实战
1. 为什么你需要JPomDocker自动化部署方案每次手动打包SpringBoot项目时你是不是也经历过这样的痛苦先在本地mvn clean package然后scp上传到服务器接着ssh连上去kill旧进程最后nohup启动新jar包。更可怕的是半夜接到报警电话睡眼惺忪地重复这套操作手抖输错命令直接把生产环境搞崩...我们团队曾经在三个月内经历了23次深夜紧急发布直到发现了JPomDocker这个黄金组合。现在只需要在GitHub上点个Merge按钮20分钟后新版本就会自动完成构建、测试、部署全流程。最让我惊喜的是这套方案对中小团队特别友好不需要搭建复杂的Jenkins集群用最轻量的方式就能实现完整的CI/CD流水线。2. 环境准备10分钟快速搭建基础环境2.1 用Docker Compose一键安装JPom先准备个干净的Linux服务器建议2核4G以上配置执行下面这个魔法命令mkdir -p ~/jpom cd ~/jpom cat docker-compose.yml EOF version: 3 services: jpom-server: image: jpomdocker/jpom ports: - 2122:2122 - 2123:2123 volumes: - /etc/localtime:/etc/localtime:ro - jpom-data:/usr/local/jpom-server restart: unless-stopped jpom-agent: image: jpomdocker/jpom ports: - 2124:2124 volumes: - /etc/localtime:/etc/localtime:ro - jpom-agent-data:/usr/local/jpom-agent environment: - JPOM_TYPEagent - JPOM_SERVERws://jpom-server:2123 depends_on: - jpom-server restart: unless-stopped volumes: jpom-data: jpom-agent-data: EOF docker-compose up -d等命令跑完打开浏览器访问 http://你的服务器IP:2122默认账号admin/123456 就能看到管理后台。这里有个小技巧建议立即修改默认密码并在系统配置里开启HTTPS毕竟安全无小事。2.2 配置Docker资产的关键细节在管理后台左侧菜单找到资产管理 - Docker管理点击新增按钮时90%的人会卡在这个配置上{ host: unix:///var/run/docker.sock, apiVersion: 1.41, certPath: , tlsVerify: false }特别注意如果JPom服务和Docker不在同一台机器需要修改host为tcp://docker主机IP:2375并且要在docker主机的/etc/docker/daemon.json中添加{ hosts: [unix:///var/run/docker.sock, tcp://0.0.0.0:2375] }记得重启docker服务sudo systemctl restart docker否则会连接失败。我当初就在这里栽过跟头排查了整整两小时。3. 项目配置实战从代码到部署的全流程3.1 创建你的第一个构建仓库在在线构建 - 仓库信息新增Git仓库时强烈建议使用SSH方式认证。这是我用血的教训换来的经验曾经用HTTPS配置的仓库经常莫名奇妙断开连接换成SSH后稳如老狗。配置示例仓库地址gitgithub.com:yourname/yourproject.git认证方式SSH密钥分支main小技巧提前把服务器的SSH公钥(~/.ssh/id_rsa.pub)添加到GitHub的Deploy Keys里这样就不需要每次输密码了。3.2 编写高效的DSL构建脚本下面这个DSL配置是我们团队经过20多次迭代优化的版本特别适合SpringBoot项目runsOn: ubuntu-latest fromTag: jdk17 steps: - uses: java version: 17 - uses: maven version: 3.9.4 - uses: cache path: /root/.m2 type: global binds: - /root/.m2:/root/.m2 - /data/maven/settings.xml:/root/.m2/settings.xml env: MAVEN_OPTS: -Xmx1024m -XX:MaxPermSize512m run: - cd ${JPOM_WORKING_DIR} mvn clean package -Dmaven.test.skiptrue -s /root/.m2/settings.xml几个关键优化点使用jdk17镜像比默认的ubuntu-latest构建速度快30%通过MAVEN_OPTS环境变量限制内存使用避免OOM把settings.xml固定映射到容器内里面配置了阿里云镜像源全局缓存Maven仓库第二次构建时间从6分钟降到40秒3.3 自动化部署的终极方案在发布操作配置环节90%的教程都只教了简单启动jar包我要分享的是企业级方案#!/bin/bash # 发布前命令 docker stop ${PROJECT_NAME} || true docker rm ${PROJECT_NAME} || true # 发布后命令 cd /app/${PROJECT_NAME} cat docker-compose.yml EOF version: 3 services: ${PROJECT_NAME}: image: openjdk:17-jdk ports: - ${PORT}:${PORT} volumes: - ./${JAR_NAME}:/app.jar command: java -jar /app.jar restart: always EOF docker-compose up -d这个方案有三大优势使用docker-compose管理服务方便后续扩展通过环境变量动态注入项目名、端口等参数自带健康检查和服务自愈能力4. 避坑指南我踩过的那些坑4.1 构建缓存失效的诡异问题有次凌晨三点被报警叫醒发现构建突然失败了。排查发现是/root/.m2目录权限被误改成了777导致Maven缓存失效。解决方案是在DSL里增加权限修复命令run: - chmod 755 /root chmod 700 /root/.m2 - cd ${JPOM_WORKING_DIR} mvn clean package4.2 Docker容器时区问题我们的报表服务总是显示UTC时间后来发现是Docker容器默认时区问题。现在每个项目都会在docker-compose.yml里加上时区配置environment: - TZAsia/Shanghai volumes: - /etc/localtime:/etc/localtime:ro4.3 内存泄漏导致构建失败某次发版时频繁出现137错误码退出监控发现是构建容器内存不足。现在我们会根据项目规模调整构建资源hostConfig: Memory: 2G MemorySwap: 3G5. 高级技巧让自动化更智能5.1 自动版本号管理在pom.xml里配置这套插件配合JPom的构建参数可以实现自动版本号递增plugin groupIdorg.codehaus.mojo/groupId artifactIdversions-maven-plugin/artifactId version2.8.1/version configuration newVersion${auto.version}/newVersion /configuration /plugin然后在JPom的构建命令里加上mvn versions:set -Dauto.version${BUILD_NUMBER}5.2 多环境配置切换通过JPom的环境变量功能可以轻松实现多环境部署。比如在DSL里这样配置env: SPRING_PROFILES_ACTIVE: ${DEPLOY_ENV}发布时选择不同的环境变量值就能自动加载对应的application-{env}.yml配置。5.3 构建通知集成在构建后操作里配置Webhook可以把构建结果同步到钉钉/企业微信。这是我们团队用的钉钉机器人配置{ msgtype: markdown, markdown: { title: 构建通知, text: ### ${PROJECT_NAME}构建结果\n 状态: ${BUILD_STATUS}\n 版本: ${BUILD_NUMBER}\n 耗时: ${BUILD_DURATION}秒\n [查看日志](${BUILD_URL}) } }

更多文章