运维自动化

3、配置Jenkins+GitLab实现持续集成与部署

2018-02-01  本文已影响13人  天夭夭

以下只演示Jenkins实现CI、CD过程中Job的创建过程。至于集成、交付所使用的脚本这里不做介绍。

一、前置条件

        配置好各服务器间的信任关系

        配置Jenkins的相关账号信息

        如gitlab账号密码、ssh key、gitlab API token、通知邮箱

        以上两步请参考Jenkins相关的配置篇章:https://www.jianshu.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、检查部署是否成功(可用端口占用、部署包版本、服务注册等方面进行检查)

上一篇 下一篇

猜你喜欢

热点阅读