一、背景
awx的模板执行结果及时通知给相关人员,可以直接在awx界面上配置通知,然后由项目和模板来决定是否开启通知。
通知类型一般选择webhook,消息体的拼接,则需要参考awx官方文档。
除了在awx界面上配置通知外,也可以在playbook脚本中增加发送消息通知,调用python等脚本实现。
本文的消息通知以企业微信的机器人为示例,讲解其配置过程。至于钉钉机器人的对接过程类似,就不重复。
对接企业微信的机器人通知,报文示例见下:
curl 'https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=693axxx6-7aoc-4bc4-97a0-0ec2sifa5aaa' \
-H 'Content-Type: application/json' \
-d '
{
"msgtype": "text",
"text": {
"content": "hello world"
}
}'
机器人地址见下截图:
至此,消息通知的准备工作就做好了,接下来在awx配置通知。
二、配置通知
1、拼接job开始、成功、错误的通知回调的入参
注意,json报文必须遵循企业微信的机器人回调报文格式。
{
"msgtype": "text",
"text": {
"content": "{{ job_friendly_name }}-{{ job.id }} \"{{ job.name }}\" is {{ job.status }}. \nuser: {{job.summary_fields.created_by.username}}"
}
}
你可以参考awx官方的webhook-payloads回调文档,定制出符合自己的消息模板。
这里摘要job实体下几个重要的字段,见下json报文:
{"id": 18,
"name": "Project - Space Procedures",
"url": "https://towerhost/#/jobs/project/18",
"created_by": "admin",
"started": "2019-10-26T00:20:45.139356+00:00",
"finished": "2019-10-26T00:20:55.769713+00:00",
"status": "successful",
"traceback": ""
}
其实,它也可以简写为{{ job_metadata }}
2、开启模板“应用重启”的通知
这样,我们将会收到两个通知消息:任务开始的通知、任务运行成功或失败的通知。
三、运行模板
企业微信收到消息通知:
-
作业运行成功
-
作业运行失败
四、自定义的webhook回调
如果你发送的消息通知,不是直接对接企业微信,而是自定义接口。
只要在把企业微信的机器人修改你的接口地址即可。
job运行成功或失败的消息体示例:
{
"created_by": "awx",
"name": "{{ job.name }}",
"status": "{{ job.status }}",
"started": "{{ job.started }}",
"finished": "{{ job.finished }}",
"env": "test"
}
关于awx如何实现回调通知,就梳理到这里了。
可以看到,消息体还是比较有限的,只能从awx官方文档里寻找。
如果你要更加灵活的消息通知,建议在playbook脚本里实现,可以读取到更多信息,比如程序的版本号。
版本号,对以应用为中心的程序部署来说,非常关键。