大家好,我是雄雄,欢迎关注微信公众号:雄雄的小课堂。
前言
服务器太多,管不过来怎么办?宝塔就退出了一款云监控面板,花里胡哨还挺有意思的,也比较实用,唯一的缺点就是能添加的服务器有限,如果多了,则需要开会员,这个钱,对于个人来说,能省就省了,省下来可以再买一台服务器…
今天,我们就来找一个能替代宝塔云监控的面板——哪吒面板。
实现效果
可以通知的消息如上所示。
前提条件
- 一个微信机器人,能通过
api
发送消息到微信群中 - 已经装好的哪吒监控面板
- 会点编程(我已
python
为例)
今天琢磨了一天,对于告警,可算是琢磨明白了,趁着现在还没忘记,就在此记录一下,回头忘记了之后,可以翻出来看看。
假设我们上面的三个前提条件都满足,那么接着往下看!
这是我的哪吒前台面板:
设置告警通知方式
下面,我们开始设置面板的告警通知方式。首先,我们进入面板的后台,找到告警,然后右上角添加【通知方式】,如下所示:
在面板消息中,占位符 #DATETIME# 代表事件发生的时间戳。当通知被触发时,面板会自动将 #DATETIME# 替换为事件的实际时间。
#NEZHA# 是面板消息占位符,面板触发通知时会自动用实际消息替换占位符。
Body 内容是 JSON 格式的:当请求类型为 FORM 时,值为 key:value 的形式,value 里面可放置占位符,通知时会自动替换。当请求类型为 JSON 时 只会简单进行字符串替换后直接提交到 URL。
URL 里面也可放置占位符,请求时会进行简单的字符串替换。
填写的信息说明:
- 名称:随便写个
- 分组:随便写个,注意,设置告警的时候,分组一定是现在写的这个,比如我的是fastapi
URL
:就是你接口的地址(该接口实现了发送消息至微信中)- 请求方式:
post
- 请求类型:
json
- header:不用写(我的接口没有设置)
- Body:也就是当达到告警之后,需要给服务器里面推送的消息是什么,直接复制我的:
{ "content": "#NEZHA#", "server_name": "#SERVER.NAME#", "server_ip": "#SERVER.IP#", "server_ipv4": "#SERVER.IPV4#", "server_ipv6": "#SERVER.IPV6#", "cpu": "#SERVER.CPU#", "mem": "#SERVER.MEM#", "swap": "#SERVER.SWAP#", "disk": "#SERVER.DISK#", "net_in_speed": "#SERVER.NETINSPEED#", "net_out_speed": "#SERVER.NETOUTSPEED#", "transfer_in": "#SERVER.TRANSFERIN#", "transfer_out": "#SERVER.TRANSFEROUT#", "load1": "#SERVER.LOAD1#", "load5": "#SERVER.LOAD5#", "load15": "#SERVER.LOAD15#", "tcp_conn_count": "#SERVER.TCPCONNCOUNT", "udp_conn_count": "#SERVER.UDPCONNCOUNT" }
然后点击确定即可。
新增告警规则
点击下面的【新增告警规则】,我们就可以添加一条告警规则了。
如何添加?可以参考我的:
填写说明:
- 名称:随便写个,到时候也会发到微信里面
- 规则,可以看看官方文档,https://nezha.wiki/guide/notifications.html#%E5%9F%BA%E6%9C%AC%E8%A7%84%E5%88%99
比如我设置的是:** CPU
持续 600 秒超过 50% **
[{"type":"cpu","max":50,"duration":600}]
- 通知方式组:与你上面设置的通知方式的分组要一致,不然没法给你通知
- 通知触发模式:始终触发或者单次触发,按照你自己的需求选择就行
- 启用:勾选上就是正式启用生效了。
使用python实现自定义告警接口,发送至微信
首先,我们需要按照告警的字段,声明一个类:
# 消息实体 class CallBackDataEntity(BaseModel): content: Optional[str] = None, # 通知事件名称 server_name: Optional[str] = None, # 服务器名称 server_ip: Optional[str] = None, # 服务器IP server_ipv4: Optional[str] = None, # 服务器IPv4 server_ipv6: Optional[str] = None, # 服务器IPv6 cpu: Optional[str] = None, # CPU使用率 mem: Optional[str] = None, # 内存使用率 swap: Optional[str] = None, # 交换分区使用率 disk: Optional[str] = None, # 磁盘使用率 net_in_speed: Optional[str] = None, # 实时上传速度 net_out_speed: Optional[str] = None, # 实时下载速度 transfer_in: Optional[str] = None, # 总上传 transfer_out: Optional[str] = None, # 总下载 load1: Optional[str] = None, # 1分钟负载 load5: Optional[str] = None, # 5分钟负载 load15: Optional[str] = None, # 15分钟负载 tcp_conn_count: Optional[str] = None, # TCP连接数 udp_conn_count: Optional[str] = None, # UDP连接数 # 创建get方法 def get(self, param): return getattr(self, param)
我这都有注释,可以直接复制下来就行。
然后我们还需要再写个接口,来实现发送到微信群中:
# 处理通知 @nezha_router.post("/gaojing") async def gaojing(data: CallBackDataEntity): # 将收到的消息转换成json data = data.dict() print(f"触发了告警消息:{data}") # 需要通知的消息 str = '' # 获取content内容 content = data.get("content") # 获取ip地址 ip = data.get("server_ip") # 获取CPU使用率 cpu = float(data.get("cpu")) # 获取内存使用情况,换算成已使用G的内存 mem = round(float(data.get("mem")) / (1024 ** 3), 2) # 存储使用情况 换算成已使用G的硬盘 disk = round(float(data.get("disk")) / (1024 ** 3), 2) # 实时下载速度 Mbs net_out_speed = round(float(data.get("net_out_speed")) / 1024, 2) # 实时上传速度 Mbs net_in_speed = round(float(data.get("net_in_speed")) / 1024, 2) # 总上传 transfer_in = round(float(data.get("transfer_in")) / (1024 ** 3), 2) # 总下载 transfer_out = round(float(data.get("transfer_out")) / (1024 ** 3), 2) # 1分钟负载 load1 = float(data.get("load1")) # 5分钟负载 load5 = float(data.get("load5")) # 15分钟负载 load15 = float(data.get("load15")) # TCP连接数 tcp_conn_count = data.get("tcp_conn_count") # UDP连接数 udp_conn_count = data.get("udp_conn_count") # 拼接通知消息 str = "⚠️⚠️⚠️哪吒面板告警⚠️⚠️⚠️\r\r" \ "🔻🔻🔻🔻🔻🔻🔻🔻🔻🔻 \r" \ f"🚫{content}\r" \ f"🖥️CPU使用率:{cpu:.2f} %\r" \ f"💾内存使用:{mem} GB\r" \ f"📤️磁盘使用:{disk} GB\r" \ f"⬆️实时上传速度:{net_in_speed} Mbs\r" \ f"⬇️实时下载速度:{net_out_speed} Mbs\r" \ f"🔼总上传:{transfer_in} GB\r" \ f"🔽总下载:{transfer_out} GB\r" \ f"🕐️1分钟负载:{load1} %\r" \ f"🕔️5分钟负载:{load5} %\r" \ f"🕞️15分钟负载:{load15} %\r " \ "🔺🔺🔺🔺🔺🔺🔺🔺🔺🔺\r\r" \ "🚸请注意检查服务器是否正常!!!" # 调用发送的接口 # 调用发送文本消息的接口发送消息 # user_nick_list = ['all'] # user_name_list = ['notify@all'] user_nick_list = [] user_name_list = [] # 需要发送的群【雄雄的大家庭】wxid fromWxid = '47747688531@chatroom' body = api_bot_utils.send_public_v37(fromWxid, 0, WECHAT_APPKEY, str, user_nick_list, user_name_list) print(f"消息发送情况,内容是:{body}") return {"message": "success"}
上面代码中的部分换算…我也是靠猜的,不知道对不对,大家可以自己看看,要是不对的话,就改改。
然后我们需要将这个python
发布到服务器上,拿到/gaojing
这个接口的地址,修改到哪吒面板中通知方式的url处即可
关于机器人相关的文档,可以联系我获取。