Jenkins构建通知
一.简介
类似于监控报警,jenkins在配置持续集成后,job的执行将自动化,这就需要每次将构建结果通知到不同载体中进行查看。
像我所在的项目中,可能时不时就发布一个test环境版本,这时候对于测试人员是不友好的,页面正在进行点击测试,突然就没反应了,正在发版中。
就需要微信/钉钉等方式进行通知,不仅告诉开发也告诉测试和运维,当前有版本正在发布。
二.推送到gitlab
当Jenkins执行完构建后,我们还可以将构建结果推送到Gitlab的相应commit记录上,这样就可以将构建状态与commit关联起来。
1.进入Jenkins-》Configure System页,找到“Gitlab”选项,填入Gitlab地址。注意“Connection name”的值,后面会使用到
2.在Credentials下拉列表中选择"GitLab API token"后,单击"Test Connection"按钮,如果返回Success,就说明集成成功了
3.在pipeline的post部分,将构建结果更新到GitLab的相应commit记录上。除此之外,还需要在options部分加入gitLab Connection配置,同时传入"gitlab”参数。"gitlab” 就是上文中提醒读者注意的"Connection name”的值。
pipeline {
agent any
triggers {
gitlab(triggerOnPush: true, triggerOnMergeRequest: true, branchFilterType:'All',
secretToken: "abcdefghijk1mnopqrstuvwxyz0123456789ABCDEF")
}
stages {
stage('build') {
steps {
echo "hello world from gitlab trigger"
}
}
post {
failure {
updateGitlabCommitStatus name: 'build', state: 'failed'
}
success {
updateGitlabCommitStatus name:'build', state: 'success'
}
}
options {
gitLabConnection( 'gitlab')
}
}
}
需要手动触发一次构建,pipeline才会生效。当前做了一次成功构建、一次失败构建的实验,在Gitlab上项目的commit列表中,显示了最近两次commit的构建状态
三.邮件通知
自带配置
我们使用163邮箱来演示如何在pipeline中加入邮件通知。
步骤如下:
1.进入Manage Jenkins→Configure System→Jenkins Location设置页面,设置管理员邮箱
提示:这一步是必不可少的;否则,在发送邮件通知时会报出"com.sun.mail.smtp.SM TPSend-FailedException : 553 Mail frommust equal authorized user”错误
2.在同一个页面中找到E-mail Notification部分
勾选“Test configuration by sending test e-mail”复选框,输入接收测试邮件的邮箱,然后单击“Test configuration”按钮,
如果提示“Email was successfully sent”,就说明配置成功。
3.在Jenkins pipeline的post部分加入mail步骤。
mail步骤的关键参数介绍如下∶
- subject,邮件主题。
- to,收件地址
- body,邮件内容
- from,发件地址
欲了解更多参数,可以到官方文档中查看
Email Extension
mailer插件提供的功能过于简单。Email Extension插件对mailer插件进行了扩展,支持更多的特性。
- 可以定制接收人的邮件列表。
- 可以将构建日志以附件形式加到邮件中,还可以设置对日志进行压缩。
- 可以发送附件
具体使用步骤如下:
1.安装Email Extension插件
2.进入Manage Jenkins→Configure System→Extended E-mailNotification配置页面
在Jenkinsfile中使用emailext步骤,因此只要配置SMTP server ,其他选项配置保持默认配置就可以了。
3.将emailext步骤加入pipeline的post部分的failure块内。
post {
failure {
emailext body:
"""<p>EXECUTED: Job <b>\ '${env. 0B_NAME}:${env.BUILD_NUMBER})\ '
</b></p><p>View console output at "<a href="${env.BUILD_URL}">
${env.JOB_NAME}:${env.BUILD_NUMBER}</a>"</p>
<p><i>(Build log is attached .)</i></p>""",
compressLog: true,
attachLog: true,
recipientProviders: [culprits(), developers(),requestor(), brokenBuildSuspects()],
replyTo: 'do-not-reply@company.com',
subject: "Status: ${currentBuild.result?: 'SUCCESS'} - Job \ '${env. 0B_NANE}: ${env.BUILD_NUMBER}\'",
to: "jenkinsbooksample@163.com"
}
}
收到邮件
emailext步骤的常用参数介绍如下∶
- subject : String类型,邮件主题。
- body : String类型,邮件内容。
- attachLog (可选):Bool类型,是否将构建日志以附件形式发送。
- attachmentsPattern (可选) : String类型,需要发送的附件的路径,Ant风格路径表达式。
- compressLog (可选):Bool类型,是否压缩日志。from(可选) : String类型,收件人邮箱。
- to (可选) : String类型,发件人邮箱。
- recipientProviders (可选): List类型,收件人列表类型。replyTo (可选):回复邮箱。
常用的收件人列表类型
提示:requestor ()会读取登录用户的邮箱(在个人资料设置页可以设置)。
关于完整的收件人列表类型,可以参考官方文档
四.钉钉通知
钉钉(DingTalk )是阿里巴巴集团开发的企业协同办公软件。本节介绍Jenkins与钉钉的集成。原理很简单,就是在钉钉群中增加一个钉钉机器人,我们将消息发送到钉钉机器人的API就可以了。
具体步骤如下:
1.配置钉钉机器人,在钉钉群的右上角单击机器人形状的图标
在弹出的机器人类型列表中,选择“Custom”(自定义)类型
按照钉钉的提示操作到达最后一步,复制webhook的URL中的accessToken的值,后面的步骤会使用到
2.安装DingTask插件
3.在Jenkinsfile中加入dingTalk步骤
dingTalk accessToken: "<accessToken值>", imageUrl: "<钉钉群里显示消息的缩略图>",jenkinsUrl:'<Jenkins的链接>',message: '<文本消息>', notifyPeople: '张三'
最后效果如图
注意:如果accessToken的值不对,dingTalk并不会报错。另外,应该使用凭证管理accessToken的值,而不是明文写在Jenkinsfile中
五.脚本钉钉通知
因为插件使用报错,就自己写了脚本达到同样效果
1.创建钉钉群,管理界面添加机器人
2.选择自定义方式
3.复制好webhook
4.选择关键字,这里配置后,消息里有发布这个词才能生效
5.在jenkins服务器上配置脚本/jen_script/dingding.py,这里钉钉用markdown语法写内容
#!/usr/local/python-3.6/bin/python3.6
import json,requests,sys,time,datetime
#[工程名、分支号、是否成功、编号]
job = sys.argv[1]
branch = sys.argv[2]
stat = sys.argv[3]
bianhao = sys.argv[4]
if int(stat) == 0:
name = '发布成功!'
tupian = '![file](https://prod-private.oss-cn-beijing.aliyuncs.com/yw/QQ%E6%88%AA%E5%9B%BE20201109153327.png)'
elif int(stat) == 1:
name = '发布失败!'
tupian = '![file](https://prod-private.oss-cn-beijing.aliyuncs.com/yw/QQ%E6%88%AA%E5%9B%BE20201109163201.png)'
url = "https://oapi.dingtalk.com/robot/send?access_token=022d90fsadaplfs8fgjsc4dc4c86cdf4ed666"
title = job + name
nowtime = datetime.datetime.now()
nowtime = str(nowtime.strftime('%Y-%m-%d %H:%M:%S'))
msg = """### %s \n
> 时间: %s \n
> 分支: %s \n
> 编号: #%s \n
> 地址: [工程链接](http://10.0.9.115:8080/job/%s) \n
%s
"""
def Alert():
headers = {"Content-Type": "application/json"}
data = {"msgtype": "markdown",
"markdown": {
"title": title,
"text": msg %(title, nowtime, branch, bianhao, job, tupian)
}
}
r = requests.post(url, data=json.dumps(data), headers=headers, verify=False)
print(r.text)
Alert()
6.在OSS的prod-private的ubcket中,yw文件夹存储着构建时通知的图片
图片放到这里,可以拿去用,都是同大小的
成功:
失败:
7.编写pipeline配置
pipeline {
agent any
options {
buildDiscarder(logRotator(numToKeepStr: '10'))
}
environment {
workspace = pwd()
release_branch = 'master'
}
post { //直接复制这段到pipeline阶段内
success {
sh "/jen_script/dingding.py ${JOB_NAME} ${release_branch} 0 ${BUILD_NUMBER}"
}
failure {
sh "/jen_script/dingding.py ${JOB_NAME} ${release_branch} 1 ${BUILD_NUMBER}"
}
}
8.发一版测试
六.HTTP请求通知
使用HTTP Request插件,我们能在Jenkins pipeline中发送HTTP请求给第三方系统。这是最通用的Jenkins与第三方系统集成的方式之一。
HTTP Request插件提供了httpRequest步骤,代码示例如下:
steps {
script{
def response = httpRequest(url: 'http://192.168.88.3:8081',acceptType:"APPLICATION_JSON",
contentType: "APPLICATION_JSON",
httpMode: "POST",
authentication: "http_request",
customHeaders:[
[name: "headername", value: "headerValue"],
[name: "token", value: "secret", maskValue: true]
],
requestBody: "{'buildNumber': '${env.BUILD_NUMBER}'}",
timeout: 5,
validResponseCodes: "200:302")
echo "${response.status}"
echo "${response.content}"
} //end of script
}
httpRequest步骤返回的response对象包含两个字段。
- content :响应内容
-status :响应码
以下是httpRequest步骤支持的参数
- url:字符串类型,请求URL
- acceptType:枚举类型,HTTP请求Header的“Accept”的值类型为NOT_SET.TEXT_HTML、TEXT_PLAIN.APPLICATION_FORM、APPLICATION_JSON、APPLICATION_JSON_UTF8、APPLICATION_TAR、APPLICATION_ZIP、APPLICATION_OCTETSTREAM。
- authentication :字符串类型,Username with password凭证的ID,采用的是HTTP Basic认证方式
- consoleLogResponseBody :布尔类型,是否将请求的响应body
打印出来 - contentType:枚举类型,HTTP请求Header的“Content-type"的值类型,与acceptType支持的枚举一样
- customHeaders : HttpRequestNameValuePair对象数组,HTTP请求Header部分的内容,该对象有3个参数
- name :字符串类型,Header名称
- value :字符串类型,Header值。
- maskValue :布尔类型,是否隐藏 Header值。如果设置为true,则在打印时使用“*”代替。
- httpMode:枚举类型,HTTP方法,有GET(默认)、HEAD.POST、PUT、DELETE、OPTIONS、PATCH。
- httpProxy:字符串类型,HTTP代理地址
- ignoreSslErrors :布尔类型,是否忽略SSL错误。
- requestBody :字符串类型,请求的body内容。
- timeout :整型,超时时间,单位为秒。默认值为0,代表不设置超时时间。
- validResponseCodes :字符串类型,代表HTTP请求成功的状态码。它支持3种格式的值。
- 单状态值:比如200,当收到200响应状态码时,表示HTTP请求成功。
- 多状态值:当响应状态码符合多个状态码中的一个时,代表请求成功。多个状态码之间使用逗号(,)分隔。比如200,404,500。
- 范围状态值∶格式为“From : To”。比如200 : 302,代表收到200到J302的响应状态码都代表请求成功。
- validResponseContent :字符串类型,比如设置它的值为"showme.codes”,那么只有当HTTP返回的内容中包含了
"showme.codes”时,才代表请求成功。 - quiet :布尔类型,是否关闭所有的日志打印,默认值为false。
- responseHandle:枚举类型,获取HTTP响应内容的方式。其值可以为
- NONE:不读取响应内容。
- LEAVE_OPEN:当执行完请求后,并不会返回响应的内容,而是返回一个打开了的inputStream,由你自己决定该如何读取响应内容。但是在使用完之后,记得调用input-Stream的close ()方法关闭。
- STRING(默认值)∶将响应内容转换成一个字符串。
- outputFile:字符串类型,请求响应内容的输出路径。
Jenkins构建通知的更多相关文章
- jekins构建通知邮件配置及邮件附件设置,jenkins构建通知邮件没有RF的log和report文件
全局配置: 系统管理-系统设置-Extended E-mail Notification (本邮件是程序自动下发的,请勿回复!)<br/><br/>项目名称:$PROJECT_ ...
- RF+Jenkins构建持续集成
引入RF是为了能够快速的开展自动化验收测试,Jenkins而一种持续集成工具,用于监控持续重复的工作,持续的软件版本发布/测试项目,而通过RF+Jenkins可以有利的对RF构建的接口项目进行持续集成 ...
- 持续集成之④:GitLab触发jenkins构建项目
持续集成之④:GitLab触发jenkins构建项目 一:目的为在公司的测试环境当中一旦开发向gitlab仓库提交成功代码,gitlab通知jenkins进行构建项目.代码质量测试然后部署至测试环境, ...
- Jenkins邮件通知
Jenkins邮件通知 Jenkins 配备了一个开箱工具,添加一个电子邮件通知的构建项目. 第1步 - 配置SMTP服务器. 转到 Manage Jenkins → Configure System ...
- Jmeter+maven+Jenkins构建云性能测试平台(mark 推荐)
转自:http://www.cnblogs.com/victorcai0922/archive/2012/06/20/2555502.html Jmeter+maven+Jenkins构建云性能测试平 ...
- Jenkins构建持续集成
Jenkins 是一个开源软件项目,旨在提供一个开放易用的软件平台,使软件的持续集成变得可能.现在软件开发追求的是效率以及质量,Jenkins使得自动化成为可能! 亮点 采用shell自定义脚本,控制 ...
- GitLab 自动触发 Jenkins 构建
GitLab 是当前应用非常广泛的 Git Hosting 工具,Jenkins 是非常牛逼的持续集成工具.尽管 GitLab 有内建的 GitLab CI,但它远没有 Jenkins 那么强大好用. ...
- sonar+Jenkins 构建代码质量自动化分析平台
1.Sonar 介绍 Sonar 是一个用于管理代码质量的开源工具,可以分析代码中的bug和漏洞以及Code Smells,支持20多种编程语言的检测,如java,c/c++,python,php等语 ...
- jenkins构建结果企业微信提醒
每当jenkin在构建之后我们想把构建结果SUCCESS/FAILURE或者其他信息通知给其他人,也许有人会说,不是有邮件提醒吗?但是我这里的环境邮件提醒的话所被通知者并不会第一时间去阅读,所以我们用 ...
随机推荐
- UDP端口检查告警SHELL脚本(企业微信版机器人版)
脚本准备 0Batch_Check.sh 1port_check.sh 2wechat_bot_alert.sh CheckList CheckList #支持大/小写 10.1.1.5 Udp 53 ...
- [atARC122F]Domination
如果一个红石头在另一个红石头的左下方(包括左和下),那么在后者的限制满足时,前者也一定满足,因此可以删去前者,再将其按照$rx_{i}$排序,即有$rx_{1}<rx_{2}<...< ...
- linux 同时执行多个命令及几个基础命令
先后不同的命令用分号:隔开即可 基础命令: 1.cd 进入目录 /代表根目录,.代表当前目录,..代表上一级目录 2.ls 显示当前目录下的所有文件和文件夹 -F区分目录和文件,文件后边是*代表可执行 ...
- [TopCoder2014Final]FrozenStandings 解法探究
https://vjudge.net/problem/TopCoder-13460 简要题意:给出 \(n\) 段从 \(1\) 到 \(n\) 编号的等长区间,保证区间的端点互不相同.区间可以选取其 ...
- FFT/NTT复习笔记&多项式&生成函数学习笔记Ⅱ
因为垃圾电脑太卡了就重开了一个... 前传:多项式Ⅰ u1s1 我预感还会有Ⅲ 多项式基础操作: 例题: 26. CF438E The Child and Binary Tree 感觉这题作为第一题还 ...
- 洛谷 P4437 [HNOI/AHOI2018]排列(贪心+堆,思维题)
题面传送门 开始 WA ycx 的遗产(bushi 首先可以将题目转化为图论模型:\(\forall i\) 连边 \(a_i\to i\),然后求图的一个拓扑序 \(b_1,b_2,\dots b_ ...
- python版的MCScan绘图
最近发现了python版的MCScan,是个大宝藏.由于走了不少弯路,终于画出美图,赶紧记录下来. github地址 https://github.com/tanghaibao/jcvi/wiki/M ...
- R 语言实战-Part 4 笔记
R 语言实战(第二版) part 4 高级方法 -------------第13章 广义线性模型------------------ #前面分析了线性模型中的回归和方差分析,前提都是假设因变量服从正态 ...
- KEGG数据库整理示例
已知KEGG数据库中ko_map.tab文件,K-->ko: 目标文件:map-->K 代码示例: #! /usr/bin/perl -w use strict; my %seq; ope ...
- mysql 中@ 和 @@的区别
@x 是 用户自定义的变量 (User variables are written as @var_name)@@x 是 global或session变量 (@@global @@session )@ ...