前置条件:

1. 配置企业微信















2. 脚本配置

2.1 安装python依赖的库

  1. # 安装pip(python2或3版本都行,这里使用默认的python2进行配置)
  2. [root@server ~]# wget https://bootstrap.pypa.io/get-pip.py
  3. [root@server ~]# python get-pip.py
  4. [root@server ~]# pip install requests

2.2 编写脚本

将这个脚本写入到:vim /usr/lib/zabbix/alertscripts/wechat.py,并赋予执行权限chmod +x /usr/lib/zabbix/alertscripts/wechat.py,代码如下:

  1. #! /usr/bin/python
  2. # _*_ coding:utf-8 _*_
  3. """
  4. Name : Liuhedong
  5. Date : 2019/4/10 19:05
  6. Mail : liuhedong135@163.com
  7. Version : Python 3.7.0
  8. IDE : Pycharm-community-2018.2.4
  9. """
  10. # 若脚本失效,请联系博主。
  11. import requests
  12. import time
  13. import json
  14. import sys
  15. class Wechat(object):
  16. def __init__(self,overdue, tkpath, tktime, touser, toparty, corpid, corpsecret, agentid, content):
  17. # 消息接收者
  18. self.touser = touser
  19. # 部门ID列表
  20. self.toparty = toparty
  21. # token路径(首先从文件读取token,如果没有就get_token)
  22. self.tkpath = tkpath
  23. # 上次请求Token的时间存放的路径(时间戳)
  24. self.tktime = tktime
  25. # Token过期时间,期间内获取的Token是一样的
  26. self.overdue = overdue
  27. # 当前时间戳
  28. self.nowtime = int(time.time())
  29. # 企业ID
  30. self.corpid = corpid
  31. # 管理组凭证
  32. self.corpsecret = corpsecret
  33. # 自建的程序管理ID
  34. self.agentid = agentid
  35. # 发送的内容
  36. self.content = content
  37. # 请求的AccessToken
  38. self.token = self.read_token()
  39. def read_token(self):
  40. try:
  41. self.token = str(open(self.tkpath,'r+').read()) # 读取token
  42. self.times = int(float(open(self.tktime,"r+").read())) # 读取时间戳(需转换为整型)
  43. self.times = self.nowtime - self.times # 时间差(当前时间-上次时间)
  44. if self.times >= self.overdue: # 如果过期就重新请求Token(超过7200)
  45. self.token = self.get_token() # 调用get_token方法重新获取
  46. return self.token
  47. else:
  48. return self.token # 否则直接返回读取到token
  49. except IOError:
  50. self.token = self.get_token() # 如果读取失败证明没请求过(第一次请求)
  51. return self.token
  52. """
  53. 该read_token方法的逻辑是:
  54. (1)读取token文件和times文件。如果出错代表是第一次运行此脚本(或被误删)
  55. 1. 发起新的请求,获取token
  56. 2. 最后返回请求到的token
  57. (2)读取token文件和time文件。没有错误就进行时间的相减
  58. 1. 企业微信API在7200内请求的token是相同的。
  59. 2. 企业微信API在1分钟内限制请求1000次。
  60. 3. 将上次发起时间与现在时间相减,如果没有超过7200s就将之前存入的token返回
  61. 4. 如果超过7200s则会发起新的请求,重新获取token
  62. 5. 最后返回请求到的token
  63. 注:在正常情况下,每次发送消息都会发起两次请求,获取token和发送消息到微信,所以此函数减少了获取token的频率。
  64. """
  65. def get_token(self):
  66. # 获取token的url
  67. url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid={}&corpsecret={}".format(self.corpid,self.corpsecret)
  68. # 发送get请求,并获取返回的内容
  69. token = requests.get(url).text
  70. # 将返回的内容(json)转为python字典格式,并获取token
  71. self.token = json.loads(token)['access_token']
  72. # 将获取到的token写入到本地文件
  73. with open(self.tkpath,'w+') as f:
  74. f.write(str(self.token))
  75. # 将当前时间的时间戳写入文件,以便下次计算过期时间
  76. with open(self.tktime,'w+') as f:
  77. f.write(str(time.time()))
  78. # 最后返回获取到的token
  79. return self.token
  80. def msg_send(self,content):
  81. # 发送消息的url
  82. url = "https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token={}".format(self.token)
  83. # 要发送的表单(需转换成json格式)
  84. data = {
  85. "touser": "|".join(self.touser),
  86. "toparty": self.toparty,
  87. "msgtype": "text",
  88. "agentid": self.agentid,
  89. "text": {
  90. "content": content
  91. },
  92. "safe": 0
  93. }
  94. # 将python字典转化为json并指定编码utf-8(默认使用ascii编码)python3会出现编码问题,将#.encode('utf-8')的#注释删除掉即可。
  95. data_json = json.dumps(data, ensure_ascii=False)#.encode('utf-8')
  96. # 发送post请求,并发送表单,
  97. response = requests.post(url, data=data_json).text
  98. # 将返回的内容(json)转为python字典格式
  99. ss = json.loads(response)
  100. # 如果返回值不正确就打印发送失败,否则返回请求到的内容
  101. if ss['errcode'] != 0 and ss['errmsg'] != "ok":
  102. return "出现错误..."
  103. else:
  104. return response # 返回请求到的结果
  105. if __name__ == '__main__':
  106. # ======================用户配置信息区域==================================
  107. # token过期时间(过期后发起新的token请求)
  108. overdue = 7200
  109. # token保存的路径(详见read_token方法描述)
  110. tkpath = '/tmp/token'
  111. # 记录token过期时间的路径(详见read_token方法描述)
  112. tktime = '/tmp/tokentime'
  113. # 消息的接收者,"@all"表示向关注该企业应用的全部成员发送,多个用户逗号分隔
  114. # 注意:接收者必须在企业微信自建应用的可见范围内。否则消息接收不到!!!
  115. touser = ("ZongCai","LiuHeDong")
  116. # 部门ID列表,"@all"表示所有部门,多个部门|分隔,例如:1|2|3|4
  117. toparty = 1
  118. # 企业自建应用的ID(在zabbix中配置并传递过来)
  119. agentid = sys.argv[1]
  120. # 企业ID
  121. corpid = "********"
  122. # 自建应用的密钥
  123. corpsecret = "********"
  124. # 要发送的内容
  125. # sys.argv[1]是zabbix传来的应用ID
  126. # sys.argv[2]是zabbix传来的标题
  127. # sys.argv[3]是zabbix传来的内容
  128. # 若想修改为指定内容,修改content变量值即可
  129. content = sys.argv[2] + '\n' + sys.argv[3]
  130. #======================================================================
  131. # 实例化微信类
  132. w = Wechat(
  133. overdue=overdue,
  134. tkpath=tkpath,
  135. tktime=tktime,
  136. touser=touser,
  137. toparty=toparty,
  138. corpid=corpid,
  139. corpsecret=corpsecret,
  140. agentid=agentid,
  141. content=content
  142. )
  143. # 调用微信实例中的发送消息方法
  144. w.msg_send(content)

2. 搭建FTP

  1. # 这里我直接在zabbix服务器安装ftp
  2. [root@server ~]# yum install vsftpd
  3. listen=YES # 修改为YES
  4. listen_ipv6=YES # 删除这一条
  5. [root@server ~]# systemctl start vsftpd

3. 配置Zabbix监控FTP

3.1 添加FTP模板









3.2 添加报警媒介



3.3 配置到用户







3.4 配置动作



  1. # 问题操作的标题:
  2. Problem:{TRIGGER.NAME}
  3. # 恢复操作的标题:
  4. Resolved: {TRIGGER.NAME}
  5. # 消息内容:
  6. Default subject:{TRIGGER.STATUS}: {TRIGGER.NAME}
  7. Trigger host:{HOSTNAME}
  8. Trigger ip:{HOST.IP}
  9. Trigger time:{EVENT.DATE}:{EVENT.TIME}
  10. Trigger: {TRIGGER.NAME}
  11. Trigger status: {TRIGGER.STATUS}
  12. Trigger severity: {TRIGGER.SEVERITY}
  13. Trigger URL: {TRIGGER.URL}
  14. Item values:
  15. {ITEM.NAME1} ({HOST.NAME1}:{ITEM.KEY1}): {ITEM.VALUE1}
  16. {ITEM.NAME2} ({HOST.NAME2}:{ITEM.KEY2}): {ITEM.VALUE2}
  17. Original event ID: {EVENT.ID}









4. 模拟故障测试

4.1 停止FTP并查看

  1. [root@server ~]# systemctl stop vsftpd





4.2 恢复FTP并查看

  1. [root@server ~]# systemctl start vsftpd



Zabbix4.2.0使用Python连接企业微信报警的更多相关文章

  1. Prometheus(五):Prometheus+Alertmanager 配置企业微信报警

    此处默认已安装Prometheus服务,服务地址:192.168.56.200  一.设置企业微信 1.1.企业微信注册(已有企业微信账号请跳过) 企业微信注册地址:https://work.weix ...

  2. Python 发送企业微信消息

    1.获取企业微信信息 1)我的企业 --> 企业信息 --> 企业ID 2)创建一个应用,记录该应用的 AgentId.Secret 2.python代码 #!/usr/bin/env p ...

  3. 使用Python发送企业微信消息

    准备工作: 到企业微信官网,注册一个企业:登录企业微信后台,创建一个“自建”应用, 获取企业ID.agentid.secret这3个必要的参数:在企业微信的通讯录中,创建多个测试账号:在手机端安装“企 ...

  4. 测试wss是否连接企业微信成功

    企业微信考勤机有时候无法连接,可以使用下面代码来测试下网络情况  <html> <head> <title>测试wss</title> </hea ...

  5. Zabbix 3.0 配置企业微信报警(注册---测试)

    一.申请企业微信 1.登录企业微信官网,点击企业注册 二.配置企业微信 1.邀请管理员使用企业微信,如果有多个人直接添加新成员 2.管理员收到邀请,下载手机版企业微信,使用微信号登陆即可 3.创建应用 ...

  6. Python接入企业微信 - 推送信息到内部群里

    前言 之前一篇文章提到了使用wechatpy库来实现企业微信应用登录:Django + Taro 前后端分离项目实现企业微信登录 其实这个库可以实现的功能非常多,基本微信开发涉及到的功能都能实现. 本 ...

  7. 配置zabbix通过微信报警企业微信报警

    如今势态: 报警的方式可谓是八仙过海各显神通,如电话报警,短信报警,邮件报警,QQ报警,微信报警等等. 电话报警:一般都是使用别的平台的工具,平台给你提供一个接口供你使用,大多数为限量收费款 短信报警 ...

  8. zabbix企业微信报警实现

    企业微信配置 # 注册 企业微信注册地址:https://work.weixin.qq.com 笔者注册的企业微信名称为 5iik # 配置 # 在主干5iik(企业名称)下添加子部门(监控组),并将 ...

  9. zabbix配置企业微信报警

    +++++++++++++++++++++++++++++++++++++++++ 1. 工作中最长使用的就是微信,普及,开源,而且免费!!! 2. 在企业微信中要记录的值: · 部门id · 企业i ...

随机推荐

  1. django.template.exceptions.TemplateDoesNotExist: rest_framework/api.html

    django.template.exceptions.TemplateDoesNotExist: rest_framework/api.html setting文件中的 INSTALLED_APPS加 ...

  2. vba文件对比并高亮显示

    每月月底要和人事要离职人员名单,并账号列表里删除已经离职人员的账号,如下代码通过将账号列表与人事发来的离职清单进行对比,高亮找出离职人员的账号,并进行删除. Sub DeleteMain() Dim ...

  3. python历史与基本类型

    前言 我自学的方式主要是看文档,看视频,第一次做写博客这么神圣的事情,内心是忐忑的,写的东西比较杂,路过的小伙伴不要嘲笑我,主要是记录一日所学,顺便锻炼一下语言组织能力吧,anyway,这些都不重要, ...

  4. ping内网一台虚拟机延时很大(hyper-v虚拟机)的解决办法

    问题现象: ping 内网一台虚拟机延时很大,不稳定,造成业务系统响应慢.查看服务器上各种资源都正常. 解决办法: 在物理机上找到和hyper-v绑定的那个网卡,把“虚拟机队列”禁用掉就好了,如下图: ...

  5. Eclipse Golang 开发环境搭建 GoClipse 插件

    Windows平台 下载完成后,直接双击安装即可 默认情况下,.msi文件会安装在 C:\Go 目录下.可以将 C:\Go\bin 目录添加到环境变量 PATH 中,方便调用命令. Go 里面有两个非 ...

  6. urlrewrite的rule怎么写

    一.正则表达式教程 常用正则如下: .              换行符以外的所有字符 \w          匹配字母或数字或下划线或汉字 \s           匹配任意的空白符 \d     ...

  7. 走进JDK(四)------InputStream、OutputStream、Reader、Writer

    InputStream InputStream是java中的输入流,下面基于java8来分析下InputStream源码 一.类定义 public abstract class InputStream ...

  8. LVS、Nginx 及 HAProxy 工作原理

    当前大多数的互联网系统都使用了服务器集群技术,集群是将相同服务部署在多台服务器上构成一个集群整体对外提供服务,这些集群可以是 Web 应用服务器集群,也可以是数据库服务器集群,还可以是分布式缓存服务器 ...

  9. 08-jQuery的位置信息

    Query的位置信息跟JS的client系列.offset系列.scroll系列封装好的一些简便api. 一.宽度和高度 获取宽度 .width() 描述:为匹配的元素集合中获取第一个元素的当前计算宽 ...

  10. Learning Rust - Syntax

    Rust is another compiling language that may replace the position of C/C++ in server filed. It runs f ...