CD工具awx之通知NOTIFICATIONS,及时发送消息到企业微信机器人

一、背景

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脚本里实现,可以读取到更多信息,比如程序的版本号。

版本号,对以应用为中心的程序部署来说,非常关键。

  • 9
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值