学习Jenkins持续集成(三)Jenkins项目构建触发器、参数化构建及邮件发送

一、构建触发器

1.常用的构建触发器

Jenkins内置4种构建触发器:

  1. 触发远程构建
    身份验证令牌 算是我们自己设置的一个token 一般是加密的

在这里插入图片描述
在这里插入图片描述

然后 通过 浏览器地址栏访问JENKINS_URL/job/wxpublic/build?token=TOKEN_NAME 或者 /buildWithParameters?token=TOKEN_NAME
JENKINS_URL替换Jenkins的地址,TOKEN_NAME替换为设置的token令牌:http://139.196.231.13:8888/job/wxpublic/build?token=liushihao即可通过远程访问,来立即构建。

  1. 其他工程构建后触发(Build after other projects are build)
    即当关注的项目构建完成后,这个项目也会触发构建
    在这里插入图片描述

  2. 定时构建(Build periodically)
    在这里插入图片描述

定时字符串从左往右分别为: 分 时 日 月 周

一些定时表达式的例子:
每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

  1. 轮询SCM(Poll SCM)
    在这里插入图片描述

轮询SCM,是指定时扫描本地代码仓库的代码是否有变更,如果代码有变更就触发项目构建。
注意:这次构建触发器,Jenkins会定时扫描本地整个项目的代码,增大系统的开销,不建议使用。
注意:设置的两分钟,不一定会构建,只有项目代码变更了后才会构建。

2.Git hook自动触发构建(*)

刚才我们看到在Jenkins的内置构建触发器中,轮询SCM可以实现Gitlab代码更新,项目自动构建,但是 该方案的性能不佳。那有没有更好的方案呢? 有的。就是利用Gitlab的webhook实现代码push到仓 库,立即触发项目自动构建。
安装Gitlab Hook插件 需要安装两个插件: Gitlab Hook和GitLab
但由于我是使用Gogs搭建的个人仓库 ,所以需要安装gogs插件
在这里插入图片描述
Jenkins设置自动构建
在这里插入图片描述
在这里插入图片描述

3.Jenkins的参数化构建

在这里插入图片描述

4.配置邮箱服务器发送构建结果

在这里插入图片描述

在这里插入图片描述
在邮箱设置中找到 开启(qq邮箱)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
email模板

<!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>项目名称&nbsp;:&nbsp;${
    
    PROJECT_NAME}</li>
                <li>构建编号&nbsp;:&nbsp;第${
    
    BUILD_NUMBER}次构建</li>
                <li>触发原因:&nbsp;${
    
    CAUSE}</li>
                <li>构建日志:&nbsp;<a href="${BUILD_URL}console">${
    
    BUILD_URL}console</a></li>
                <li>构建&nbsp;&nbsp;Url&nbsp;:&nbsp;<a href="${BUILD_URL}">${
    
    BUILD_URL}</a></li>
                <li>工作目录&nbsp;:&nbsp;<a href="${PROJECT_URL}ws">${
    
    PROJECT_URL}ws</a></li>
                <li>项目&nbsp;&nbsp;Url&nbsp;:&nbsp;<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>
            <b><font color="#0B610B">变更信息:</font></b>
            <hr size="2" width="100%" align="center" />
        </td>
    </tr>
    <tr>
        <td>
            <ul>
                <li>上次构建成功后变化 :  ${
    
    CHANGES_SINCE_LAST_SUCCESS}</a></li>
            </ul>
        </td>
    </tr>
    <tr>
        <td>
            <ul>
                <li>上次构建不稳定后变化 :  ${
    
    CHANGES_SINCE_LAST_UNSTABLE}</a></li>
            </ul>
        </td>
    </tr>
    <tr>
        <td>
            <ul>
                <li>历史变更记录 : <a href="${PROJECT_URL}changes">${
    
    PROJECT_URL}changes</a></li>
            </ul>
        </td>
    </tr>
<!--    <tr>-->
<!--        <td>-->
<!--            <ul>-->
<!--                <li>变更集:${
    
    JELLY_SCRIPT,template="html"}</a></li>-->
<!--            </ul>-->
<!--        </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>

添加发送邮件脚本:
在这里插入图片描述

在这里插入图片描述
发送邮件脚本:

pipeline {
    
    
    agent any

    stages {
    
    
        stage('拉取代码') {
    
    
            steps {
    
    
                checkout([$class: 'GitSCM', branches: [[name: '*/master']], doGenerateSubmoduleConfigurations: false, extensions: [], submoduleCfg: [], userRemoteConfigs: [[credentialsId: '00b15bbd-d044-4db1-9eb6-063c16781dc4', url: 'http://139.196.231.13:3000/liushihao/monitor.git']]])
            }
        }
        stage('编译构建') {
    
    
            steps {
    
    
                sh label: '', script: 'mvn clean package'
            }
        }
         stage('构建完成') {
    
    
            steps {
    
    
                echo '构建完成'
            }
        }
    }
    post {
    
    
          always {
    
    
             emailext(
                subject: '构建通知:${PROJECT_NAME} - Build # ${BUILD_NUMBER} - ${BUILD_STATUS}!',
                body: '${FILE,path="email.html"}',
                to: '******@qq.com,******[email protected],******[email protected]'
             )
          }
    }
}

效果:
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/DreamsArchitects/article/details/109320993