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

相关推荐
xiaobaibai15316 分钟前
营销自动化终极形态:AdAgent 自主闭环工作流全解析
大数据·人工智能·自动化
池央2 小时前
CANN 诊断工具链深度解析:oam-tools 的自动化故障信息收集、软硬件状态快照与 AI Core 错误溯源机制
运维·人工智能·自动化
池央2 小时前
CANN 算子合规性与迁移性:自定义算子设计中的安全边界与属性兼容性
人工智能·自动化·信号处理
乾元3 小时前
终端安全(EDR):用深度学习识别未知勒索软件
运维·人工智能·网络协议·安全·网络安全·自动化·安全架构
麦兜*3 小时前
全面掌握深度学习部署技术:基于TensorRT与Triton Inference Server实现高性能模型推理和自动化Pipeline的企业级落地实践指南
人工智能·深度学习·自动化
_运维那些事儿14 小时前
VM环境的CI/CD
linux·运维·网络·阿里云·ci/cd·docker·云计算
zhengfei61117 小时前
自动化快速评估工具
运维·自动化
m_1368717 小时前
n8n 启动时报 EACCES permission denied 的完整排查与修复
自动化·n8n
少云清18 小时前
【金融项目实战】6_接口测试 _Jmeter自动化脚本实现(重点)
jmeter·自动化·金融项目实战
木童66219 小时前
Ruo-Yi 项目 CI/CD 详细部署文档
ci/cd