在配置Email之前我们需要下载两个插件: Email Extension
, Email Extension Template
,这两个插件可以帮助我们进行邮件的编写发送以及格式化
系统管理
-> 插件管理
中下载插件:
找到所要配置邮箱的基础信息,这里以QQ邮箱为例
系统管理->系统配置
中,最底部找到 邮件通知
,打开 高级
:
Test configuration
来先测试一下邮件的发送
Test configuration
会出现以下报错: javax.mail.AuthenticationFailedException: 535 Login Fail. Please enter your authorization code to login. More information in http://service.mail.qq.com/cgi-bin/help?subtype=1&&id=28&&no=1001256 复制代码这是因为使用QQ邮箱登录,需要填入的是QQ邮箱的授权码,这是用于登录第三方客户端的专用密码。具体的获取方式可参考: service.mail.qq.com/cgi-bin/hel…
java.net.SocketException: Connection closed by remote host 复制代码这是因为我们还需要在设置
Jenkins Location
中配置
系统管理员邮件地址
,此地址要和
邮件通知
中的
用户名
一致
做完了上述步骤后再次测试可以看到邮件发送成功
记得文章一开头提到的下载Extended插件,没错,Jenkins系统设置里还可以通过 Extended E-mail Notification
对邮件发送进行模板格式的自定义
基础信息配置与上述一致,唯一要注意的是这里需要重新生成一个授权码
这里主要就是配置展示的模板格式,常用的格式化的参数有:
- $BUILD_STATUS – 构建结果 - $PROJECT_NAME – 构建脚本名称 - $BUILD_NUMBER – 构建脚本编号 - $JOB_DESCRIPTION – 构建项目描述 - $CAUSE – 脚本启动原因 - $BUILD_URL – 脚本构建详情URL地址 复制代码
这里选择以HTML的格式展示,填入模板:
<hr/>(自动化构建邮件,无需回复!)<br/><hr/> 项目名称:$PROJECT_NAME<br/><br/> 项目描述:$JOB_DESCRIPTION<br/><br/> 运行编号:$BUILD_NUMBER<br/><br/> 运行结果:$BUILD_STATUS<br/><br/> 触发原因:${CAUSE}<br/><br/> 构建日志地址:<a href="${BUILD_URL}console">${BUILD_URL}console</a><br/><br/> 构建地址:<a href="$BUILD_URL">$BUILD_URL</a><br/><br/> 详情:${JELLY_SCRIPT,template="html"}<br/> <hr/> 复制代码
我们还可以在 Default Triggers
中根据自己的需要配置邮件的触发条件
这里为了防止因为构建一直尝试结果均为失败而造成的邮件轰炸,可以设置邮件仅第一次或第二次构建结果为失败时才发送邮件,后续失败的邮件将不再发送
Editable Email Notification
"
Recipient List
中配置的邮件地址