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这东西,用好了真能解放生产力,建议大家都试试。

相关推荐
中海德--陈顺真20 小时前
西屋模块 1C31129G01
自动化
ManageEngineITSM1 天前
IT服务台为什么越忙越低效?
人工智能·自动化·excel·itsm·工单系统
飞Link1 天前
逆向兼容的桥梁:3to2 自动化降级工具实现全解析
运维·开发语言·python·自动化
FS_Marking1 天前
ZTP(零接触配置):实现自动化与高效的网络部署
运维·网络·自动化
IT23101 天前
抖音作品自动化监控工具
运维·自动化
GeeLark1 天前
GeeLark 3月功能更新合集
ai·自动化·aigc
tianyuanwo1 天前
Kickstart 自动化安装中的密码管理:rootpw 与 chpasswd 完全指南
运维·自动化·kickstart
weixin_449310841 天前
电商对账革命:破解效率困局,拥抱自动化转型
运维·自动化
Agent产品评测局1 天前
企业工单处理自动化落地,派单回访全流程闭环实现:2026架构升级与多方案全景盘点
运维·人工智能·ai·架构·自动化