Z投稿 | Zabbix 5.0 企业微信 WebHook 实现故障文本告警

感谢本文作者小谈谈!

Z投稿 | Zabbix 5.0 企业微信 WebHook 实现故障文本告警_第1张图片

Zabbix 5.0对于告警(报警媒介)进行了扩展和优化,可以直接支持 WebHook 类型的报警媒介。我们再开发企业微信机器人可以直接通过 JavaScript 语言编写脚本,因为得到了 Zabbix 的原生支持,告警脚本通用性强且更加灵活。本文将分享如何通过 Zabbix 报警媒介在企业微信发送告警信息。

一、注册企业微信机器人

首先需要先在自己的企业微信群里创建一个机器人,并获取其WebHook地址。右击群聊天卡片,添加群机器人。

Z投稿 | Zabbix 5.0 企业微信 WebHook 实现故障文本告警_第2张图片

为你的机器人起一个名字,点击确定,获得一个类似下图的WebHook地址。注意,这个 WebHook 地址非常重要,请不要泄露,否则他人可以通过这个地址给你捣乱。把这个地址复制出来,后面需要用到。

Z投稿 | Zabbix 5.0 企业微信 WebHook 实现故障文本告警_第3张图片

二、创建告警媒介

登录Zabbix,依次选择“管理”、“报警媒介类型”、“创建媒体类型”。名称随意,只要能起到一个标识作用即可。媒介类型选择WebHook,参数按下表填写。

Z投稿 | Zabbix 5.0 企业微信 WebHook 实现故障文本告警_第4张图片

这里的Key就是刚刚注册机器人时候生成的 WebHook 地址末尾的 Key,例如你的地址是https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=574c6d4e-544c-4baf-ae9a-b935dbc1be46,则这里你需要填写574c6d4e-544c-4baf-ae9a-b935dbc1be46。

脚本可以参考如下的代码段。直接复制到脚本代码框中即可。

var Qiyeweixin = {

  key: null,

  message: null,

  msgtype: "markdown",

  proxy: null,

  sendMessage: function(){

    var params = {

        msgtype: Qiyeweixin.msgtype,

        markdown: {

          content: Qiyeweixin.message,

        },

      },

      data,

      response,

      request = new CurlHttpRequest(),

      url =

        "https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=" +

        Qiyeweixin.key;

    if (Qiyeweixin.proxy) {

      request.setProxy(Qiyeweixin.proxy);

    }

    request.AddHeader("Content-Type: application/json");

    data = JSON.stringify(params);

    // Remove replace() function if you want to see the exposed key in the log file.

    Zabbix.Log(

      4,

      "[Qiyeweixin Webhook] URL: " + url.replace(Qiyeweixin.key, "")

    );

    Zabbix.Log(4, "[Qiyeweixin Webhook] params: " + data);

    response = request.Post(url, data);

    Zabbix.Log(4, "[Qiyeweixin Webhook] HTTP code: " + request.Status());

    try {

      response = JSON.parse(response);

    } catch (error) {

      response = null;

    }

    if (request.Status() !== 200 || response.errcode !== 0) {

      if (typeof response.errmsg === "string") {

        throw response.errmsg;

      } else {

        throw "Unknown error. Check debug log for more information.";

      }

    }

  },

};

try {

  var params = JSON.parse(value);

  if (typeof params.Key === "undefined") {

    throw 'Incorrect value is given for parameter "Key": parameter is missing';

  }

  Qiyeweixin.key = params.Key;

  if (params.HTTPProxy) {

    Qiyeweixin.proxy = params.HTTPProxy;

  }

  Qiyeweixin.to = params.To;

  Qiyeweixin.message = params.Subject + "\n" + params.Message;

  Qiyeweixin.sendMessage();

  return "OK";

} catch (error) {

  Zabbix.Log(4, "[Qiyeweixin Webhook] notification failed: " + error);

  throw "Sending failed: " + error + ".";

}


超时给10s即可。最后配置完成后,应该是如下图的样子。

Z投稿 | Zabbix 5.0 企业微信 WebHook 实现故障文本告警_第5张图片

创建消息模板。Zabbix已经预制了一些模版可以直接拿来用,也可以自定义。

Z投稿 | Zabbix 5.0 企业微信 WebHook 实现故障文本告警_第6张图片

在模板中是支持markdown语法的。目前支持的 markdown 语法是如下的子集。这是由企业微信机器人开发文档定义的。

1. 标题(支持1至 6 级标题,注意#与文字中间要有空格)

2. 加粗

3. 链接

4. 行内代码段(不支持跨行)

5. 引用

6. 字体颜色(有三种内置颜色)

三、测试告警媒介

编辑完成,点击“添加”,回到报警媒介类型页面。找到刚刚添加的报警媒介,在动作栏下面对应位置点击“测试”。

Z投稿 | Zabbix 5.0 企业微信 WebHook 实现故障文本告警_第7张图片

在“Test media type”对话框中,可以直接点击“测试”,也可以自定义通知的主题和内容,如图。

Z投稿 | Zabbix 5.0 企业微信 WebHook 实现故障文本告警_第8张图片

测试成功,在Zabbix端会提示“Media type test successful.”,同时在企业微信里也会收到刚刚发出来的测试消息。

Z投稿 | Zabbix 5.0 企业微信 WebHook 实现故障文本告警_第9张图片

四、配置通知消息

到现在,就已经成功开发了一个企业微信告警机器人,现在我们要把他配置到通知消息里。首先对用户配置告警媒介。如下图,你也可以选择启动机器人的时间段,比如我要7x24小时盯着网络设备,这里直接 007 就好了。

Z投稿 | Zabbix 5.0 企业微信 WebHook 实现故障文本告警_第10张图片

创建一个动作,发送消息给某些用户,并仅送到“Qiyeweixin”这个告警媒介。

Z投稿 | Zabbix 5.0 企业微信 WebHook 实现故障文本告警_第11张图片

这样,当有设备触发器被触发产生告警时,企业微信机器人就会给你发消息了。

Z投稿 | Zabbix 5.0 企业微信 WebHook 实现故障文本告警_第12张图片

你可能感兴趣的:(Z投稿 | Zabbix 5.0 企业微信 WebHook 实现故障文本告警)