以下只演示Jenkins实现CI、CD过程中Job的创建过程。至于集成、交付所使用的脚本这里不做介绍。
一、前置条件
配置好各服务器间的信任关系
配置Jenkins的相关账号信息
如gitlab账号密码、ssh key、gitlab API token、通知邮箱
以上两步请参考Jenkins相关的配置篇章://www.greatytc.com/p/4e0a67fb3360
二、Jenkins创建任务
1、创建CI的项目
此项目需要配置“源码管理”、“构建”及“构建后操作”。
1.1、源码管理:
1.2、构建:
1.3、构建后操作:
2、创建CD的项目
此项目需要配置“构建”及“构建后操作”。
2.1、构建
2.2、构建后操作:
3、创建管道项目
此项目需要配置“General”、“Build Triggers”及“Pipeline”。
3.1、General
3.2、Build Triggers
在Jenkins服务器上生成随机token:
# openssl rand -hex 12
0f2a47c861133916d2e299e3
对应生成GitLab触发Jenkins钩子地址格式:
http://jenkins服务器地址:8080/buildByToken/build?job=jenkins项目名&token=token值
本人创建中产生的链接为:http://192.168.12.235:8080/buildByToken/build?job=test_pipeline&token=0f2a47c861133916d2e299e3
3.3、Pipeline
到此点击保存即完成了管道项目的创建
4、GitLab挂webhook(钩子)
4.1、进入GitLab操作台(并选择进入要挂Webhook的项目)
此处进入的为“test_ci_cd"项目
然后点击下方的“Add wehook”
添加之后在下方会形成一条添加记录。点击“Test”即可验证配置是否成功(成功将触发一次Jenkins完成的Job)
----------------------------------------------------------------------------------------------------------------------------
点击“Test”后若出现如下提示信息,则说明配置确认。
----------------------------------------------------------------------------------------------------------------------------
点击“Test”后若出现如下出现警告,则说明配置异常。
----------------------------------------------------------------------------------------------------------------------------
返回Jenkins管理页面,将查看到刚触发wehook的执行记录。
进入管道项目中查看本次各个项目的执行时间,及状态。
点击进入单个项目的某执行记录,还可查看对应的日志。
到此便完成Jenkins+GitLab实现持续集成与持续部署。
具体实现集成与部署需要根据不同的场景,采取相应的脚本。此处不提供的脚本在于,每个系统的开发语言、及依赖服务都各不相同,所以脚本内容不具备通用性。
笔者脚本中大部分使用了shell和少量的Python,Python比较多是用于部署完后的自动化测试。脚本思路编写如下:
CI过程:
1、使用maven编译代码,生产部署包(PHP项目一般无该过程);
2、验证生产部署包是否正常可用(会让部署包运行起来,并验证接口),验证后删除;
3、将验证能运行的部署包发送至分发服务器上;
CD过程:
1、分发服务器将部署包发送至本次要更新的服务器上(可使用rsync或ansible等工具);
2、应用服务器上执行更新部署;
3、检查部署是否成功(可用端口占用、部署包版本、服务注册等方面进行检查)