文章目录
一、常用的构建触发器
Jenkins 内置4种构建触发器
① 触发远程构建
② 其他工程构建后触发(Build after other projects are build)
③ 定时构建(Build periodically)
④ 轮询SCM(Poll SCM)
1. 触发远程构建
2. 其他工程构建后触发
开始构建前置项目
前置工程构建成功
回到web_demo_pipeline项目查看是否自动构建
3. 定时构建
定时字符串从左往右分别为: 分 时 日 月 周
#一些定时表达式的例子:
每30分钟构建一次:H代表形参 H/30 * * * * 10:02 10:32
每2个小时构建一次: H H/2 * * *
每天的8点,12点,22点,一天构建3次: (多个时间点中间用逗号隔开) 0 8,12,22 * * *
每天中午12点定时构建一次 H 12 * * *
每天下午18点定时构建一次 H 18 * * *
在每个小时的前半个小时内的每10分钟 H(0-29)/10 * * * *
每两小时一次,每个工作日上午9点到下午5点(也许是上午10:38,下午12:38,下午2:38,下午
4:38) H H(9-16)/2 * * 1-5
4. 轮询SCM
轮询SCM,是指定时扫描本地代码仓库的代码是否有变更,如果代码有变更就触发项目构建
注意:这次构建触发器,Jenkins会定时扫描本地整个项目的代码,增大系统的开销,不建议使用。
修改代码
提交代码
gitlab仓库查看是否提交成功
提交代码以后自动进行构建
tomcat服务器查看发布结果
等待二分钟查看是否继续构建
总结:
定时构建和轮询SCM的区别在于,定时构建不会去查看项目中代码的变化,到时间就自动构建,而轮询SCM会根据指定的时间扫描本地代码仓库的代码是否有变更,如果代码有变更就触发项目构建
二、Gitlab配置webhook
1. 开启webhook功能
Gitlab 服务器上使用 root 账户登录到后台,点击Admin Area -> Settings -> Network
勾选"Allow requests to the local network from web hooks and services"
切换到当前项目下进行设置
2. 在项目添加webhook,添加webhook和Gitlab插件
点击项目->Settings->Integrations
项目配置
进行测试
报错解决
Manage Jenkins->Configure System
回到gitlab上再次test
idea中更改开发环境代码并进行代码提交
三、Jenkins的参数化构建
-
有时在项目构建的过程中,我们需要根据用户的输入动态传入一些参数,从而影响整个构建结果,这时我们可以使用参数化构建
-
Jenkins支持非常丰富的参数类型
1. 构建配置
回到web_demo_pipeline项目中取消所有构建触发器选项
保存成功后会看到下面的效果
接下来演示通过输入gitlab项目的分支名称来部署不同分支项目
2. 项目创建分支,并推送到Gitlab上
创建分支
对V1分支的代码进行更改并提交
四、配置邮箱服务器发送构建结果
1. 安装Email Extension插件
2. Jenkins设置邮箱相关参数
往下拖会看到此选项
在添加邮件地址前,先开启邮箱SMTP功能
授权码:wehkuxrcptigbaji
Jenkins本地系统配置
邮箱参数设置
在QQ邮箱中可以看到详细的信息
配置测试
3. 准备邮件内容
切换提交分支master
在项目根目录编写email.html,并把文件推送到Gitlab,内容如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>${ENV, var="JOB_NAME"}-第${BUILD_NUMBER}次构建日志</title>
</head>
<body leftmargin="8" marginwidth="0" topmargin="8" marginheight="4" offset="0">
<table width="95%" cellpadding="0" cellspacing="0"
style="font-size: 11pt; font-family: Tahoma, Arial, Helvetica, sans- serif">
<tr>
<td>(本邮件是程序自动下发的,请勿回复!)</td>
</tr>
<tr>
<td><h2>
<font color="#0000FF">构建结果 - ${BUILD_STATUS}</font>
</h2></td>
</tr>
<tr>
<td><br />
<b><font color="#0B610B">构建信息</font></b>
<hr size="2" width="100%" align="center" /></td>
</tr>
<tr>
<td>
<ul>
<li>项目名称 : ${PROJECT_NAME}</li>
<li>构建编号 : 第${BUILD_NUMBER}次构建</li>
<li>触发原因: ${CAUSE}</li>
<li>构建日志: <a
href="${BUILD_URL}console">${BUILD_URL}console</a></li>
<li>构建 Url : <a href="${BUILD_URL}">${BUILD_URL}</a></li>
<li> 工 作 目 录 : <a href="${PROJECT_URL}ws">${PROJECT_URL}ws</a></li>
<li>项目 Url : <a href="${PROJECT_URL}">${PROJECT_URL}</a></li>
</ul>
</td>
</tr>
<tr>
<td><b><font color="#0B610B">Changes Since Last Successful Build:</font></b>
<hr size="2" width="100%" align="center" /></td>
</tr>
<tr>
<td>
<ul>
<li> 历 史 变 更 记 录 : <a href="${PROJECT_URL}changes">${PROJECT_URL}changes</a></li>
</ul> ${CHANGES_SINCE_LAST_SUCCESS,reverse=true, format="Changes for Build #%n:<br />%c<br />",showPaths=true,changesFormat="<pre>[%a]<br
/>%m</pre>",pathFormat=" %p"}
</td>
</tr>
<tr>
<td><b>Failed Test Results</b>
<hr size="2" width="100%" align="center" /></td>
</tr>
<tr>
<td><pre
style="font-size: 11pt; font-family: Tahoma, Arial, Helvetica, sans-serif">$FAILED_TESTS</pre>
<br /></td>
</tr>
<tr>
<td><b><font color="#0B610B">构建日志 (最后 100行):</font></b>
<hr size="2" width="100%" align="center" /></td>
</tr>
<tr>
<td><textarea cols="80" rows="30" readonly="readonly" style="font-family: Courier New">${BUILD_LOG,
maxLines=100}</textarea>
</td>
</tr>
</table>
</body>
</html>
变量的帮助指南获取
邮件模板提交到gitlab的master分支上
4. 编写Jenkinsfile添加构建后发送邮件
Post代码模板生成指南:项目配置中点击《流水线语法》
编写Jenkinsfile添加构建后发送邮件,添加蓝色选中取余的代码段
post {
always {
emailext(
subject: '构建通知:${PROJECT_NAME} - Build # ${BUILD_NUMBER} - ${BUILD_STATUS}!',body: '${FILE,path="email.html"}', to: '772147186@qq.com'
)
}
}
编写好Jenkinsfile脚本后提交