您的位置 首页 java

详解Jenkins 实现Gitlab事件自动触发Jenkins构建及钉钉消息推送

实践环境

GitLab Community Edition 12.6.4

Jenkins 2.284

Post build task 1.9( JENKINS 插件)

Generic Webhook Trigger Plugin 1.72( Jenkins 插件)

GitLab 1.5.13( Jenkins 插件)

实现步骤

钉钉 机器人配置

选择要推送的钉钉群 -> 点击群设置按钮 -> 点击智能群助手 -> 点击添加机器人 -> 点击添加机器人+号按钮 -> 点击自定义->填写机器人名字,用于匹配推送消息请求体内容的的关键词

然后,复制出 Webhook 地址,供下文钉钉消息推送 Shell 脚本中使用,完成

安装Jenkins插件新建并配置Jenkins项目Build Triggers配置

如下,勾选 Generic Webhook Trigger

Post content parameters (因为 Gitlab 触发的请求为 post 请求,需要基于请求体内容来判断是否执行 Jenkins 构建)关键配置项说明:

Variable 自定义变量名称

Expression 用于提取变量值的表达式(支持 JSONPath XPath ),提取的值赋值给上述自定义变量(例中为 event_name )。

Option Filter 关键配置项说明:

Expression 用于匹配下述 Text 的正则表达式,如果匹配则执行构建请求,否则不执行。这里配置为 ^push$ ,是因为 Gitlab merge 合并代码操作触发的请求,其请求体为 JSON 格式数据,其中包含名为 event_name 的键,其值为 push

Text 用于匹配上述正则表达式的文本,例中设置为自定义变量 $event_name

以上配置大意为,如果收到构建请求,使用 JSONPath 表达式从 JSON 格式的请求体获取键为 event_name 的值,存储到名为 event_name 变量,然后取该变量值同正则表达式 ^push$ 匹配,如果匹配,则触发 Jenkins 构建当前项目,否则不构建。

Token:自定义token值,用于请求 触发构建使用,如下,可以用于查询参数、请求头参数

 /invoke?token=TOKEN_HEREtoken: TOKEN_HEREAuthorization: Bearer TOKEN_HERE
  

generic-webhook-trigger 配置参考连接
Jenkins .io/generic-webhook-trigger/

Post-build Actions 配置

点击 Add post-build action 按钮,弹出界面中选择 Post build task 可新增以下配置界面。如下,可在 Script 输入框中编写构建完成后需要执行的Shell命令(该插件会先根据填写的 shell 命令生成一个临时sh脚本,然后执行该脚本),例中为钉钉推送命令,具体代码参见下文

如上图,如果只希望构建成功才执行 Script ,可以勾选 Run script only if all previous steps were successful

钉钉消息推送Shell

 #!/bin/bash
#################################################################
# 作者:shouke
# 日期:2021-03-07
# 作用:机器人通知
#################################################################
# 钉钉消息变量定义
#################################################################
# 当前时间
TIME_NOW=`date "+%Y年%m月%d日 %H:%M:%S"`
BUILD_STATUS="失败"
LAST_BUILD_BUILD_XML=`curl  --user juser_name:123456`
BUILD_RESULT=$(echo $LAST_BUILD_BUILD_XML | grep "<result>SUCCESS</result>") 
if [ "${BUILD_RESULT}" ];then 
    BUILD_STATUS="成功"
else
    BUILD_RESULT=$(echo $LAST_BUILD_BUILD_XML | grep "<result>FAILURE</result>") 
    if [ "${BUILD_RESULT}" ];then 
        BUILD_STATUS="失败"
    else
        BUILD_STATUS="无法获取"     
    fi
fi   
# 机器人 webhook 地址(上文添加钉钉机器人结束时复制的webhook地址)
DINGTALK_WEBHOOK_URL='#39;
# 消息标题 # 实际不起作用,但是不能少,否则发送失败
DINGTALK_TITLE="XX平台有新的构建,请及时查阅"
# 消息正文
# Jenkins Job构建日志地址
JENKINS_JOB_BUILD_LOG_URL="{JOB_NAME}/${BUILD_NUMBER}/console"
DINGTALK_TEXT="## xx平台有新的构建,请及时查阅nn>
**【通知时间】**:${TIME_NOW}nn>
**【构建ID】**:${BUILD_DISPLAY_NAME}nn>
**【构建项目】**:${JOB_NAME}nn>
**【构建状态】**:${BUILD_STATUS}nn>
**[点击查看更多](${JENKINS_JOB_BUILD_LOG_URL})**n
" 
#  
# 发送钉钉消息通知函数
#################################################################
function SEND_MESSAGE_TO_DINGTALK() {
    /usr/bin/curl "$1" -H 'Content-Type: application/json' -d "
    {
        " markdown ": {
            "title": "$2", 
            "text": "$3"
        }, 
        "at": {
          "atMobiles": [],
          "isAtAll": false
        },
        "msgtype": "markdown"
    }
    " 
}
# 发送钉钉消息
#################################################################
SEND_MESSAGE_TO_DINGTALK "${DINGTALK_WEBHOOK_URL}" "${DINGTALK_TITLE}" "${DINGTALK_TEXT}"
  

说明:

curl –user juser_name:123456

一名为 juser_name 的用户,使用密码123456访问指定项目的最后一次构建相关的信息,返回xml文档

注意:钉钉聊天窗口中要实现消息换行必须使用两个 n

Gitlab 自动触发配置

Settings -> Integration ,打开如下页面,

  1. 填写URL( ),这里的 token 值即为 generic-webhook-trigger 插件中配置在定义 token
  2. 勾选 Push events 触发器(这里以push、合并代码操作为例子,所以仅勾选该事件)
  3. 勾选 Enable SSL verification 复选框(如果没有勾选的话,默认就是勾选的)

最后点击 Add webhook 按钮

添加的配置,会自动显示在下方,可以对其进行事件触发测试

触发的记录会自动在配置编辑页面下方显示,点击 View details 按钮,可以查看请求明细

注意: 自动触发时 Jenkins 项目构建时,如果 Jenkins 使用了参数化构建插件 Build With Parameters Plugin ,并且使用插件实现的参数有设置默认值,则自动触发时也会自动使用对应参数的默认值进行构建。

钉钉消息推送效果图

到此这篇关于使用Jenkins完成钉钉消息推送及Gitlab事件自动触发的Jenkins构建的文章就介绍到这了

文章来源:智云一二三科技

文章标题:详解Jenkins 实现Gitlab事件自动触发Jenkins构建及钉钉消息推送

文章地址:https://www.zhihuclub.com/190900.shtml

关于作者: 智云科技

热门文章

网站地图