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

相关推荐
西部森林牧歌1 小时前
Arbess安装配置:3分钟完成国产CI/CD工具私有化部署
ci/cd·arbess·tiklab devops
p***c9491 小时前
GitLab CI/CD变量
git·ci/cd·gitlab
西部森林牧歌10 小时前
CI/CD工具选型指南:Jenkins与Arbess深度对比
ci/cd·jenkins·arbess·tiklab devops
Aruanjian88813 小时前
手动处理售后太慢?RPA智能处理小红书工单,效率提升1200%[特殊字符]
自动化·微信小店·视频号·自动化流程机器人·ai7982020·希音·抖店
知兀16 小时前
私有化部署的gitlab的push failed问题,使用http远程连接(使用token或用户、密码)
gitlab
SongYuLong的博客16 小时前
Ubuntu24.04搭建GitLab服务器
运维·服务器·gitlab
guygg8816 小时前
Linux服务器上安装配置GitLab
linux·运维·gitlab
地球没有花16 小时前
gitlab cicd 模块解释
运维·ci/cd·gitlab
小鱼小鱼.oO17 小时前
GitHub Actions 和 GitLab CI/CD
ci/cd·gitlab·github