百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

zabbix 5系列之微信实时告警(微信告警通知)

suiw9 2024-11-16 00:33 24 浏览 0 评论

1. 微信报警:

Zabbix除了可以使用邮件报警和钉钉告警之外,还可以通过微信报警,或者只要有api,你能想到的告警方式,zabbix都能实现。越灵活的告警机制越能及时有效地把告警信息推送到负责人,方便及时处理问题。

看这篇文章之前,最好看我的上篇钉钉告警,因为在这篇文章中,媒介的设置,动作的设置等介绍得比较简单,主要是功能实现,在上篇文章中,每个参数都有详细介绍。

zabbix 5系列之钉钉实时告警

1.1 微信企业号注册:

企业号注册地址:https://qy.weixin.qq.com/填写企业注册信息,个人也可以申请,不进行认证即可进行告警测试。

企业微信申请好后,可以在通讯录添加部门,以及运维人员,如果是测试,直接给管理员发也是可以的。

1.2 创建应用:

点击应用管理--点击下方创建应用--上传应用logo--输入应用名字--选择可见范围(可以是整个部门,也可以是指定人员),创建好后如下:

1.3 微信接口调试:

https://open.work.weixin.qq.com/wwopen/devtool/interface?doc_id=15074

1.4 配置微信脚本:

### 创建脚本:
[root@localhost src]# cat > /usr/lib/zabbix/alertscripts/wechat <<EOF
#!/usr/bin/python2.7
#_*_coding:utf-8 _*_

import requests,sys,json
import urllib3
urllib3.disable_warnings()

reload(sys)
sys.setdefaultencoding('utf-8')

def GetTokenFromServer(Corpid,Secret):
    Url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken"
    Data = {
        "corpid":Corpid,
        "corpsecret":Secret
    }
r = requests.get(url=Url,params=Data,verify=False)
    print(r.json())
    if r.json()['errcode'] != 0:
        return False
    else:
        Token = r.json()['access_token']
        file = open('/tmp/zabbix_wechat_config.json', 'w')
        file.write(r.text)
        file.close()
        return Token

def SendMessage(User,Agentid,Subject,Content):
    try:
        file = open('/tmp/zabbix_wechat_config.json', 'r')
        Token = json.load(file)['access_token']
file.close()
    except:
        Token = GetTokenFromServer(Corpid, Secret)

    n = 0
    Url = "https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=%s" % Token
    Data = {
        "touser": User,         # 指定用户告警,web中绑定用户的账号
        #"totag": Tagid,        # 指定企业号中的标签id,群发使用
        "toparty": Partyid,     # 指定企业号中的部门id,群发时使用。
        "msgtype": "text",      # 消息类型。
        "agentid": Agentid,     # 企业号中的应用id。
        "text": {
            "content": Subject + '\n' + Content
},
        "safe": "0"
    }
    r = requests.post(url=Url,data=json.dumps(Data),verify=False)
    while r.json()['errcode'] != 0 and n < 4:
        n+=1
        Token = GetTokenFromServer(Corpid, Secret)
        if Token:
            Url = "https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=%s" % Token
            r = requests.post(url=Url,data=json.dumps(Data),verify=False)
            print(r.json())
    return r.json()
    
if __name__ == '__main__':
    User = sys.argv[1]
    Subject = str(sys.argv[2])
    Content = str(sys.argv[3])
    # CorpID 企业号的标识
    Corpid = "ww5922d1****"
    # Secret 应用凭证密钥,在应用管理-点击机器人-查看secret可以得到
    Secret = "PfrnUym8qOw5s64*"
    # 通讯录标签ID
    #Tagid = "1"
    # 应用ID
    Agentid = "1000008"
    # 部门ID
    Partyid = "1"
    Status = SendMessage(User,Agentid,Subject,Content)
    print Status

### 安装模块:
[root@localhost src]# yum install python-pip -y
[root@localhost src]# pip install requests

# 测试脚本:
[root@node1 alertscripts]# ./wechat lutixia test "nginx down"
{u'invalidparty': u'1', u'invaliduser': u'', u'errcode': 0, u'errmsg': u'ok'}

1.5 web端创建报警媒介:

1.6 用户绑定媒介:

1.7 配置动作:

1.8 测试告警:

### 在122服务器,关闭redis服务:
[root@localhost ~]# systemctl stop redis
### 在122服务器,开启redis服务:
[root@localhost ~]# systemctl start redis

1.9 发送部门/组告警:

上面的告警是针对某人告警,在用户绑定媒介那里send to user这个user是通讯录中用户的账号(唯一标识,不是姓名)。如果是想对某个部门告警,那么这个user写啥就无所谓了,只需要修改脚本,把touser改为toparty,然后在脚本中指定Partyid的值即可。

#!/usr/bin/python2.7
#_*_coding:utf-8 _*_
。。。
       # "touser": User,        # 把发送用户注释掉
        "toparty": Partyid,     # 把发送部门打开
        "msgtype": "text",     
        "agentid": Agentid,     
。。。
    # 通讯录标签ID 
    #Tagid = "1"
    # 应用ID
    Agentid = "1000008"
    # 指定部门ID(在通讯录中可以看到)
    Partyid = "2"
。。。

1.10 测试告警:

### 在122服务器,关闭redis服务:
[root@localhost ~]# systemctl stop redis

以上就是微信告警的配置,实验起来不难,有问题可以评论区交流。

欢迎点赞收藏,你的喜欢就是我原创的动力,zabbix 5系列将会持续更新。

相关推荐

俄罗斯的 HTTPS 也要被废了?(俄罗斯网站关闭)

发布该推文的ScottHelme是一名黑客,SecurityHeaders和ReportUri的创始人、Pluralsight作者、BBC常驻黑客。他表示,CAs现在似乎正在停止为俄罗斯域名颁发...

如何强制所有流量使用 HTTPS一网上用户

如何强制所有流量使用HTTPS一网上用户使用.htaccess强制流量到https的最常见方法可能是使用.htaccess重定向请求。.htaccess是一个简单的文本文件,简称为“.h...

https和http的区别(https和http有何区别)

“HTTPS和HTTP都是数据传输的应用层协议,区别在于HTTPS比HTTP安全”。区别在哪里,我们接着往下看:...

快码住!带你十分钟搞懂HTTP与HTTPS协议及请求的区别

什么是协议?网络协议是计算机之间为了实现网络通信从而达成的一种“约定”或“规则”,正是因为这个“规则”的存在,不同厂商的生产设备、及不同操作系统组成的计算机之间,才可以实现通信。简单来说,计算机与网络...

简述HTTPS工作原理(简述https原理,以及与http的区别)

https是在http协议的基础上加了一层SSL(由网景公司开发),加密由ssl实现,它的目的是为用户提供对网站服务器的身份认证(需要CA),以至于保护交换数据的隐私和完整性,原理如图示。1、客户端发...

21、HTTPS 有几次握手和挥手?HTTPS 的原理什么是(高薪 常问)

HTTPS是3次握手和4次挥手,和HTTP是一样的。HTTPS的原理...

一次安全可靠的通信——HTTPS原理

为什么HTTPS协议就比HTTP安全呢?一次安全可靠的通信应该包含什么东西呢,这篇文章我会尝试讲清楚这些细节。Alice与Bob的通信...

为什么有的网站没有使用https(为什么有的网站点不开)

有的网站没有使用HTTPS的原因可能涉及多个方面,以下是.com、.top域名的一些见解:服务器性能限制:HTTPS使用公钥加密和私钥解密技术,这要求服务器具备足够的计算能力来处理加解密操作。如果服务...

HTTPS是什么?加密原理和证书。SSL/TLS握手过程

秘钥的产生过程非对称加密...

图解HTTPS「转」(图解http 完整版 彩色版 pdf)

我们都知道HTTPS能够加密信息,以免敏感信息被第三方获取。所以很多银行网站或电子邮箱等等安全级别较高的服务都会采用HTTPS协议。...

HTTP 和 HTTPS 有何不同?一文带你全面了解

随着互联网时代的高速发展,Web服务器和客户端之间的安全通信需求也越来越高。HTTP和HTTPS是两种广泛使用的Web通信协议。本文将介绍HTTP和HTTPS的区别,并探讨为什么HTTPS已成为We...

HTTP与HTTPS的区别,详细介绍(http与https有什么区别)

HTTP与HTTPS介绍超文本传输协议HTTP协议被用于在Web浏览器和网站服务器之间传递信息,HTTP协议以明文方式发送内容,不提供任何方式的数据加密,如果攻击者截取了Web浏览器和网站服务器之间的...

一文让你轻松掌握 HTTPS(https详解)

一文让你轻松掌握HTTPS原文作者:UC国际研发泽原写在最前:欢迎你来到“UC国际技术”公众号,我们将为大家提供与客户端、服务端、算法、测试、数据、前端等相关的高质量技术文章,不限于原创与翻译。...

如何在Spring Boot应用程序上启用HTTPS?

HTTPS是HTTP的安全版本,旨在提供传输层安全性(TLS)[安全套接字层(SSL)的后继产品],这是地址栏中的挂锁图标,用于在Web服务器和浏览器之间建立加密连接。HTTPS加密每个数据包以安全方...

一文彻底搞明白Http以及Https(http0)

早期以信息发布为主的Web1.0时代,HTTP已可以满足绝大部分需要。证书费用、服务器的计算资源都比较昂贵,作为HTTP安全扩展的HTTPS,通常只应用在登录、交易等少数环境中。但随着越来越多的重要...

取消回复欢迎 发表评论: