机器人推送告警信息之@具体人员(四)

刚开始对接完钉钉机器人报警的效果是这样的:

后面想一般群里的消息基本上没有人去看,需要增加一个@具体人的功能,然后一并把消息提醒的结构优化一下,套用现成的模板。

在网上找了一个比较好的模板:

{{/* Alert List Begin */}}
{{ define "example.__text_alert_list" }}{{ range . }}

**{{ .Annotations.message }}**

[Prometheus](Prometheus地址) | [Alertmanager](Alertmanager地址) | [Grafana](Grafana地址)

{{ range .Labels.SortedPairs }}> - {{ .Name }}: {{ .Value | markdown | html }}
{{ end }}
{{ end }}{{ end }}
{{/* Alert List End */}}

{{/* Message Title Begin */}}
{{ define "example.title" }}{{ template "__subject" . }}{{ end }}
{{/* Message Title End */}}

{{/* Message Content Begin */}}
{{ define "example.content" }}

{{ if gt (len .Alerts.Firing) 0 -}}
{{ template "example.__text_alert_list" .Alerts.Firing }}
{{- end }}

{{ if gt (len .Alerts.Resolved) 0 -}}
{{ template "example.__text_alert_list" .Alerts.Resolved }}
{{- end }}
{{- end }}
{{/* Message Content End */}}

效果是这样的:

 结果提示说 "example.title","example.content" 未定义。后来又找了一个这个:

{{ define "ding.link.content" }}
{{ if gt (len .Alerts.Firing) 0 -}}
告警列表:
-----------
{{ template "__text_alert_list" .Alerts.Firing }}
{{- end }}
{{ if gt (len .Alerts.Resolved) 0 -}}
恢复列表:
{{ template "__text_resolve_list" .Alerts.Resolved }}
{{- end }}
{{- end }}

效果如下: 

1、创建模板,目录为 /config/example.tmpl,如下图:

2、修改 config.example.yml

templates:
  - /usr/local/prometheus-webhook-dingtalk/config/example.tmpl
  
targets:
  webhook1:
    url: https://oapi.dingtalk.com/robot/send?access_token=aceff59d093d2589ff07e2fff33544d48a928dc6ad2b1dbcb42b08669d33a046
    mention:
      mobiles: ['手机号...', '手机号...']
    message:
      text: |
        @手机号... @手机号...
        {{ template "ding.link.content" . }}
这里需要注意的地方:
1)消息模板的路径要写全路径,不然就不生效,但是不报错,还是用的默认的消息结构
2)url 的地址就是钉钉群机器人的 webhook 地址
3)注意 message 的 text 的语法,加竖线,需要@的人的电话直接写,不需要加其他。
4)网上的教程说需要@的电话号码必须在 mention 的 mobiles 里加上,这个不加会不会@不到,未做验证。

3、修改 alertmanager.yml

global:
  resolve_timeout: 1m
route:
  group_by: ['severity','alertname']
  group_wait: 10s
  group_interval: 10s
  repeat_interval: 1h
  receiver: webhook1
  routes:
    - match_re:
        severity: warning
      receiver: webhook1
receivers:
  - name: 'webhook1'
    webhook_configs:
      - url: http://localhost:8060/dingtalk/webhook1/send
        send_resolved: true
这里需要注意的地方:
1)这里配一个 receivers 的话,上面 receiver 的值要和 receivers 里面 name 的值要对应上。
route:
  receiver: 'ops_dingding' #默认的接收器
  
receivers:
  - name: 'ops_dingding'
    webhook_configs:
      url: 'http://192.19.192.65:8060/dingtalk/webhook1/send'
      send_resolved: true

2)这里合理的配置应该是配置两个 receivers,分别为 webhook1 和 webhook2。上面的 receiver 指定 webhook1,group_by 增加 severity 组,配置 routes 的 severity 为 warning,这个和 Prometheus 的告警规则文件中的 severity 要一致。webhook2 接收 severity 为 warning 的告警,webhook1 接收其他告警。

route:
  group_by: ['severity','alertname']
  group_wait: 10s
  repeat_interval: 1h
  receiver: webhook1
  routes:
    - match_re:
        severity: warning
      receiver: webhook2

receivers:
  - name: 'webhook1'
    webhook_configs:
      - &dingtalk_config
        send_resolved: false
        url: http://localhost:8060/dingtalk/webhook1/send

  - name: 'webhook2'
    webhook_configs:
      - <<: *dingtalk_config
        url: http://localhost:8060/dingtalk/webhook2/send

3)修改 prometheus-webhook-dingtalk 的服务启动脚本,原先启动命令配置的是 --ding.profile=ops_dingding=机器人webhook地址,现在我们需要修改成 --config.file=config.example.yml。

[Unit]
 Description=https://github.com/timonwong/prometheus-webhook-dingtalk/releases/
 After=network-online.target

 [Service]
 Restart=on-failure
 ExecStart=/usr/local/prometheus-webhook-dingtalk/prometheus-webhook-dingtalk --config.file=/usr/local/prometheus-webhook-dingtalk/config.example.yml

 [Install]
 WantedBy=multi-user.target

4)如果用 --ding.profile=ops_dingding= 启动的话,receivers 的 webhook_configs 的 url 里面的 ops_dingding 要和 --ding.profile=ops_dingding= 指定的一致。

receivers:
  - name: 'ops_dingding'
    webhook_configs:
      url: 'http://192.19.192.65:8060/dingtalk/webhook1/send'
      send_resolved: true
./prometheus-webhook-dingtalk --ding.profile="webhook1=https://oapi.dingtalk.com/robot/send?access_token=xxx"

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
### 回答1: 企业微信机器人是一种能够自动发送告警信息的工具。Python是一种强大的编程语言,可以用于编写企业微信机器人告警信息功能。 在使用Python编写企业微信机器人告警信息功能时,我们可以使用企业微信提供的API接口来发送告警信息。首先,我们需要在企业微信后台创建一个机器人,并获取到机器人的Webhook地址。然后,使用Python的requests库发送POST请求到这个Webhook地址,将告警信息作为请求的参数发送给企业微信。 在编写Python代码时,可以使用requests库中的post方法来发送POST请求。首先需要导入requests库,然后设置请求的URL和告警信息的内容。最后,调用post方法发送请求。 下面是一个简单的示例代码: ``` import requests def send_alert(alert_message): url = "企业微信机器人的Webhook地址" data = { "msgtype": "text", "text": { "content": alert_message } } response = requests.post(url, json=data) if response.status_code == 200: print("告警信息发送成功") else: print("告警信息发送失败") # 调用发送告警信息的函数 send_alert("服务器发生故障!") ``` 以上代码中,首先设置了企业微信机器人的Webhook地址,然后构造了一个包含告警信息的字典data。接下来,使用requests库的post方法发送POST请求,并根据返回的状态码判断告警信息是否发送成功。 通过这种方式,Python可以很方便地实现企业微信机器人告警信息功能,帮助企业及时接收并处理可能的故障和异常情况。 ### 回答2: Python 企业微信机器人可以方便地实现告警信息推送和管理。企业微信是一款企业级即时通讯工具,通过Python编写的机器人可以与企业微信平台进行交互,实现告警信息的即时推送和管理。 使用Python编写的企业微信机器人可以通过调用企业微信提供的接口,将告警信息发送给指定的用户或群组。例如,当系统出现故障或发生异常情况时,可以通过Python脚本获取相关信息,并使用机器人告警信息推送给相关的人员,以便及时处理和解决问题。 通过Python编写的企业微信机器人还可以实现告警信息的管理和统计。机器人可以获取和记录告警信息,并对其进行分类、过滤和统计。例如,可以记录每天的告警次数、告警级别等信息,以便进行分析和监控,及时发现系统瓶颈和异常情况。 此外,Python编写的企业微信机器人还可以实现自定义的告警推送规则和方式。可以根据不同的告警类型和级别,设置不同的推送方式,如消息、邮件、电话等。可以根据具体需求定制机器人的行为,提高告警信息的及时性和准确性。 总之,Python 企业微信机器人是一种高效、灵活和方便的告警信息管理工具。通过使用Python编写的机器人,可以实现告警信息的即时推送和管理,提高团队的工作效率和问题处理速度。 ### 回答3: Python 企业微信机器人是一种使用 Python 编写的工具,用于向企业微信发送告警信息。企业微信是一款企业即时通讯应用,而告警信息是指在系统运行过程中出现的异常情况或重要事件,需要及时通知相关人员处理的消息。 Python 企业微信机器人具有以下优点: 1. 简便易用:使用 Python 编写的机器人代码简洁明了,易于理解和维护。只需要导入相关库,编写少量代码即可实现告警信息的发送。 2. 定制化:机器人支持自定义告警信息的格式和内容。可以根据业务需求,灵活设定告警级别、告警内容、接收人等参数。 3. 高效可靠:Python 语言具有良好的性能和稳定性,在发送告警信息时能够保证消息的实时性和可靠性。 4. 扩展性强:Python 拥有丰富的第三方库,可以结合其他库实现更多功能需求。例如,可以通过调用其他库获取系统监控数据,将实时监控数据与告警信息结合发送,提高系统监控和告警的综合能力。 使用 Python 企业微信机器人发送告警信息的流程一般如下: 1. 导入企业微信机器人相关库。 2. 设置企业微信机器人的相关参数,如机器人的 Webhook URL、告警等级、接收人等。 3. 构造告警信息的内容,可以包括日期、时间、异常信息等。 4. 将告警消息通过机器人发送给企业微信内指定的接收人。 通过以上步骤,企业微信机器人就可以快速将告警信息发送给相关人员,及时通知和解决系统运行中出现的异常情况,提高系统的可用性和稳定性。同时,通过 Python 的灵活性和丰富的第三方库支持,机器人还可以进一步扩展自己的功能,以满足不同场景下的告警需求。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值