GitLab CI/CD自动化部署实践

先说说环境准备。我们项目是标准的SpringBoot后端,服务器用的CentOS 7。要在GitLab里跑CI/CD,得先准备好GitLab Runner。这里有个坑,Runner最好单独准备一台服务器,别跟应用服务器混用。我选了shell执行器,虽然安全性不如Docker,但部署起来简单,适合初学者。

接下来是重头戏------编写.gitlab-ci.yml配置文件。这个文件决定了整个流水线怎么跑,我把它放在项目根目录下。先定义三个阶段:

编译阶段用的是Maven,这里要注意缓存配置,不然每次都要重新下载依赖,慢得要死:

最关键的是部署阶段。我们公司服务器需要通过跳板机连接,所以得先用ssh-agent配置密钥转发:

这里有几个实用技巧:StrictHostKeyChecking=no是为了避免第一次连接时的确认提示;密钥文件要提前存到GitLab的CI/CD变量里,变量名设为SSH_PRIVATE_KEY;重启脚本要提前放在服务器上,内容大致是备份旧jar包、kill旧进程、启动新进程。

部署过程中踩过不少坑。有一次Runner一直连不上服务器,排查半天发现是防火墙没开22端口。还有次脚本执行到一半卡住了,原来是因为后台进程没正确关闭,导致端口占用。后来在重启脚本里加了端口检测逻辑:

现在我们的流程已经稳定运行一个月了,每次推送代码都能自动完成编译部署。虽然前期配置花了些时间,但长期来看效率提升非常明显。特别是紧急修复时,改完代码直接push,五分钟后就能上线,再也不用半夜爬起来部署了。

接下来打算继续优化,比如加入自动化测试阶段,在部署前先跑单元测试;还要设置不同环境,开发分支自动部署到测试环境,主干分支才上生产环境。CI/CD这东西,用好了真能解放生产力,建议大家都试试。

相关推荐
极限实验室2 小时前
程序员爆哭!我们让 COCO AI 接管 GitLab 审查后,团队直接起飞:连 CTO 都说“这玩意儿比人靠谱多了
人工智能·gitlab
一只会奔跑的小橙子10 小时前
APP升级测试检查清单
自动化
测试人社区-千羽13 小时前
生物识别系统的测试安全性与漏洞防护实践
运维·人工智能·opencv·安全·数据挖掘·自动化·边缘计算
Wpa.wk14 小时前
自动化测试-鼠标+键盘操作 - Actions高级控件
java·开发语言·测试工具·自动化·计算机外设·actions·高级控件
我送炭你添花15 小时前
Pelco KBD300A 模拟器:05.校验算法终极对比 + 完整 100+ 指令封装 + KBD300A 所有隐藏功能函数化
python·算法·自动化·运维开发
科士威传动15 小时前
如何为特定应用选型滚珠导轨?
人工智能·科技·机器人·自动化·制造
song50117 小时前
鸿蒙 Flutter 复杂表单验证:自定义规则与联动逻辑
分布式·python·flutter·ci/cd·分类
UpgradeLink17 小时前
开源Electron应用GitHubActions自动化部署与升级指南
electron·开源·自动化
测试人社区-小明18 小时前
医疗AI测试:构建安全可靠的合规体系
运维·人工智能·opencv·数据挖掘·机器人·自动化·github