本帖最后由 做自己的女王ヽ 于 2018-3-2 15:32 编辑
下面介绍一下比较重要的配置项。 关闭邮件通知 这个选项在维护项目时非常有用,可以临时关闭邮件通知,避免把不必要的邮件发送给用户。 收件人列表
收件人邮件地址,多于一个时需要使用逗号分隔。 邮件类型
和全局设置中的邮件类型一样,没有特殊要求的话保留默认类型即可。此时会应用全局设置 中的类型。 默认标题
标题的默认内容为:$DEFAULT_SUBJECT,也就是在全局配置中设置的内容。如果觉着不爽 可以进行深度定制,也就是使用系统提供的变量进行拼凑。至于能拿到什么变量,可以参考 Conten Token Reference 的内容: 点击问号图标就会列出所有可用的变量,实在是太多了,就不贴出来占篇幅了! 默认内容
默认内容为:$DEFAULT_CONTENT,也是在全局配置中设置的内容。和默认标题一样,你 也可以自行定义。但多数情况下都会使用后面介绍的邮件模板,这里就不啰嗦了。 附件
有时把一些 Build 产物作为通知邮件的附件是很有用的。这里我们也可以轻松实现: 我们可以指定文件的名称,也可以使用通配符。
除了 Build 的产物,Build 的日志也是极其重要的信息。它可以帮助我们快速的调查 Build 过 程中的各种问题,所以也应该把 Build 日志添加为邮件的附件: 测试一下,收到的邮件带了两个附件: 邮件模板邮件的内容可以包含大量的信息,如果每个项目中都自己组织这些信息会费时费力。使用邮 件的模板功能可以极大的提高生产力!
Email Extension 插件支持两种类型的邮件模板,分别是 Jelly 模板和 Groovy 模板。当前的 现状是 Groovy 模板正在逐步的取代 Jelly 模板。但是两种模板的设置和使用方式基本一样, 我们以 Groovy 模板为例进行介绍。
在 Email Extension 插件的官方文档中可以找到模板的下载地址。笔者以下载的 groovy-html. template 文件为例进行说明。首先是安装邮件模板,其实就是把模板文件复制到 Jenkins 安 装目录下的 email-templates 目录中,如果该目录不存在就先创建它。
接着我们可以测试一下安装的模板是否能正常工作。打开一个添加了 "Editable Email Notification" 的项目,你会发现在左边的菜单中多了一项 "Email Template Testing": 选择这个菜单项并且输入刚才安装的模板名称: 点击 "Go" 按钮,一个预览的邮件内容就会出现在下面的空白处。
最后我们需要在邮件通知的配置中应用这个模板。其实就是设置 Default Content 为:
${SCRIPT, template="groovy-html.template"}
好了,邮件的模板设置已经完成,赶快触发个 Build 看看结果吧! Pipeline 支持Email Extension 插件支持 pipeline, 下面的代码可以很好的工作: - stage('test') {
- steps {
- echo 'hello'
- // error 'build failed'
- }
- post {
- success {
- emailext (
- subject: "SUCCESSFUL: Job '${env.JOB_NAME} [${env.BUILD_NUMBER}]'",
- to: "nick@xxxxx.com",
- body: """<p>SUCCESSFUL: Job '${env.JOB_NAME} [${env.BUILD_NUMBER}]':</p>
- <p>Check console output at "<a href='${env.BUILD_URL}'>${env.JOB_NAME} [${env.BUILD_NUMBER}]</a>"</p>""",
- recipientProviders: [[$class: 'DevelopersRecipientProvider']]
- )
- }
- failure {
- emailext (
- subject: "FAILED: Job '${env.JOB_NAME} [${env.BUILD_NUMBER}]'",
- to: "nick@xxxxx.com",
- body: """<p>FAILED: Job '${env.JOB_NAME} [${env.BUILD_NUMBER}]':</p>
- <p>Check console output at "<a href='${env.BUILD_URL}'>${env.JOB_NAME} [${env.BUILD_NUMBER}]</a>"</p>""",
- recipientProviders: [[$class: 'DevelopersRecipientProvider']]
- )
- }
- }
- }
复制代码上面的代码在 stage 执行成功或者失败的情况下发送邮件。但邮件的内容只是简单的纯文本 或这是 HTML 格式的文本。笔者尝试在 pipeline 代码中使用邮件模板的功能,但不管是 Jelly 模板还是 Groovy 模板都不能正常工作,所以这里还有待完善的功能。 总结Email Extension 是一款可定制性强、功能全面的 Jenkins 邮件通知插件。随着 pipeline 日渐成为主流的持续集成方式,希望能 Email Extension 也能紧跟趋势提供对 pipeline 更 好的支持。
|