检查设备是正常,若异常发送钉钉告警
说明:
-
通过sshpass命令,来远程执行命令(有很多检测方法,由于本人的需求较为特殊,所以需要使用这种方式来验证是否正常)
-
脚本中的webhook变量,为自己钉钉告警机器人的webhook,如图
-
钉钉机器人需要注意设置关键字,如果告警内容中无关键字,则不会发送告警
-
这里只做了简单地钉钉消息告警(针对本人的需求),如果需要更丰富的内容,可通过此链接自行查看
-
如果有单独需要sshpass远程执行命令,或者钉钉告警用法,此脚本也可参考,或许用处不大,只做分享。
import os
import time
import random
import requests
import json
def send(message):
webhook = "" # 自行修改自己的钉钉机器人webhook
data = {
"msgtype": "text",
"text": {
"content": message
},
}
headers = {'Content-Type': 'application/json'}
requests.post(url=webhook, data=json.dumps(data), headers=headers)
ip = ['192.168.1.1','192.168.1.2','192.168.1.3','192.168.1.4','192.168.1.5','192.168.1.6','192.168.1.7','192.168.1.8','192.168.1.9','192.168.1.10','192.168.1.11','192.168.1.12',]
password = "123456" # 自行填充密码
while True: # 需要24小时检测,所以加了死循环,也需不是很合理,但是目前还没发现问题,只是不通会一直告警(本人需要)
one_ip = random.choice(ip) # 因特殊情况,使用了随机模块
now_time = time.strftime("%Y-%m-%d %H:%M:%S")
a = os.popen('sshpass -p %s ssh -o "StrictHostKeyChecking no" -q root@%s "w"' % (password, one_ip)).read()
time.sleep(2)
if 'days' in a:
message = now_time+ ' - ' + one_ip + ' - 正常'
else:
message = now_time+ ' - ' + one_ip + ' - 异常'
send(message)
with open("/data/script/monitoring.log", 'a+') as f: # 需要有记录,所有加了输出日志,不需要可以删掉
f.write(str(message))
f.write("\n")
time.sleep(10)