--- outline: deep --- 哪吒监控支持对服务器的负载、CPU、内存、硬盘、流量、月流量、进程数、连接数进行监控,并在其中某项达到用户设定值时发送报警通知

## 灵活的通知方式 在面板消息中,占位符 `#DATETIME#` 代表事件发生的时间戳。当通知被触发时,面板会自动将 `#DATETIME#` 替换为事件的实际时间。 `#NEZHA#` 是面板消息占位符,面板触发通知时会自动用实际消息替换占位符 Body 内容是`JSON` 格式的:**当请求类型为 FORM 时**,值为 `key:value` 的形式,`value` 里面可放置占位符,通知时会自动替换。**当请求类型为 JSON 时** 只会简单进行字符串替换后直接提交到`URL`。 URL 里面也可放置占位符,请求时会进行简单的字符串替换。 你可以参考以下的通知方式示例,也可以根据自己的需求灵活设置推送方式 - **Bark 示例** - 名称:Bark - URL 组成: 第一个部分是 key,之后有三个匹配 /:key/:body or /:key/:title/:body or /:key/:category/:title/:body - 请求方式: GET - 请求类型: 默认 - Body: 空 - 名称:Bark - URL 组成: /push - 请求方式: POST - 请求类型: form - Body: `{"title": "#SERVER.NAME#","device_key":"xxxxxxxxx","body":"#NEZHA#","icon":"https://xxxxxxxx/nz.png"}` - **Server 酱示例** - 名称:Server 酱 - URL:https://sc.ftqq.com/SCUrandomkeys.send?title=哪吒报警信息&desp=#NEZHA# - 请求方式: GET - 请求类型: 默认 - Body: 空 - **Server 酱进阶** - 名称:Server 酱 - URL:https://sc.ftqq.com/SCUrandomkeys.send - 请求方式: POST - 请求类型: FORM - Body: ```json { "title": "#SERVER.NAME#", "desp":"**#NEZHA#\n\n 平均负载: \"#SERVER.LOAD1#\",\"#SERVER.LOAD5#\",\"#SERVER.LOAD15#\"\n\n ## [点击访问面板](https://你的面板域名)\n\n ![logo](https://raw.githubusercontent.com/naiba/nezha/master/resource/static/brand.svg)" } ``` ![展示](https://github.com/iilemon/nezhahq.github.io/blob/main/docs/images/photo_2023-03-16_00-22-47a.jpg?raw=true) - **wxpusher 示例,需要关注你的应用** - 名称: wxpusher - URL:http://wxpusher.zjiecode.com/api/send/message - 请求方式: POST - 请求类型: JSON - Body: `{"appToken":"你的appToken","topicIds":[],"content":"#NEZHA#","contentType":"1","uids":["你的uid"]}` - **Telegram 示例 贡献者:[@haitau](https://github.com/haitau)** - 名称:telegram 机器人消息通知 - URL:https://api.telegram.org/botXXXXXX/sendMessage?chat_id=YYYYYY&text=#NEZHA# - 请求方式: GET - 请求类型: 默认 - Body: 空 - URL 参数获取说明:botXXXXXX 中的 XXXXXX 是在 telegram 中关注官方 @Botfather ,输入/newbot ,创建新的机器人(bot)时,会提供的 token(在提示 Use this token to access the HTTP API:后面一行)这里 'bot' 三个字母不可少。创建 bot 后,需要先在 telegram 中与 BOT 进行对话(随便发个消息),然后才可用 API 发送消息。YYYYYY 是 telegram 用户的数字 ID。与机器人@userinfobot 对话可获得。 - **邮件通知示例 - SendCloud 贡献者:[@白歌](https://github.com/cantoblanco)** **注意:SendCloud 有每日免费发送邮件限额限制,这里仅作示例,你可以选择付费服务或其他类似的免费服务,使用方法类似。** - 名称:邮件告警 - URL:https://api.sendcloud.net/apiv2/mail/send?apiUser=<替换APIUSER>apiKey=<替换APIKEY>&from=<自定义发件邮箱>&fromName=Nezha&to=<自定义收件邮箱>&subject=Nezha-Notification&html=#NEZHA# - 请求方式: POST - 请求类型: JSON - Header: 留空 - Body: 留空 URL 参数获取说明:此方式需提前在 [SendCloud](https://www.sendcloud.net/) 注册账号,创建发件邮箱,然后在[这里](https://www.sendcloud.net/sendSetting/apiuser)获取 APIUSER 和 APIKEY,替换 URL 中的 <替换APIUSER> 和 <替换APIKEY> 为自己的 APIUSER 和 APIKEY,替换 URL 中的 <自定义发件邮箱> 和 <自定义收件邮箱> 为自己的发件邮箱和收件邮箱。 - **企业微信 群机器人 示例 贡献者:[@ChowRex](https://github.com/ChowRex)** 支持的占位符一览 ```json { "content": "#NEZHA#", "ServerName": "#SERVER.NAME#", "ServerIP": "#SERVER.IP#", "ServerIPV4": "#SERVER.IPV4#", "ServerIPV6": "#SERVER.IPV6#", "CPU": "#SERVER.CPU#", "MEM": "#SERVER.MEM#", "SWAP": "#SERVER.SWAP#", "DISK": "#SERVER.DISK#", "NetInSpeed": "#SERVER.NETINSPEED#", "NetOutSpeed": "#SERVER.NETOUTSPEED#", "TransferIn": "#SERVER.TRANSFERIN#", "TranferOut": "#SERVER.TRANSFEROUT#", "Load1": "#SERVER.LOAD1#", "Load5": "#SERVER.LOAD5#", "Load15": "#SERVER.LOAD15#", "TCP_CONN_COUNT": "#SERVER.TCPCONNCOUNT", # 无效 "UDP_CONN_COUNT": "#SERVER.UDPCONNCOUNT", # 无效 } ``` > [群机器人配置说明 - 文档 - 企业微信开发者中心](https://developer.work.weixin.qq.com/document/path/91770#markdown%E7%B1%BB%E5%9E%8B) - 名称:企业微信群机器人 - URL:https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=YOUR_BOT_KEY - 请求方式: POST - 请求类型: JSON - Body: ```json { "msgtype": "markdown", "markdown": { "content": "# 哪吒通知消息\n\n\"#NEZHA#\"\n\n> 名称: \"#SERVER.NAME#\"\n> IP: \"#SERVER.IP#\"\n> IPv4: \"#SERVER.IPV4#\"\n> IPv6: \"#SERVER.IPV6#\"\n> CPU: \"#SERVER.CPU#\"\n> 内存: \"#SERVER.MEM#\"\n> 交换分区: \"#SERVER.SWAP#\"\n> 存储: \"#SERVER.DISK#\"\n> 实时上传速度: \"#SERVER.NETINSPEED#\"\n> 实时下载速度: \"#SERVER.NETOUTSPEED#\"\n> 总上传: \"#SERVER.TRANSFERIN#\"\n> 总下载: \"#SERVER.TRANSFEROUT#\"\n> 1分钟内负载: \"#SERVER.LOAD1#\"\n> 5分钟内负载: \"#SERVER.LOAD5#\"\n> 15分钟内负载: \"#SERVER.LOAD15#\"\n> TCP连接数: \"#SERVER.TCPCONNCOUNT\"\n> UDP连接数: \"#SERVER.UDPCONNCOUNT\"\n\n" } } ``` 根据需求删减相关内容信息即可 ![通知效果](https://user-images.githubusercontent.com/30169860/223605620-eac53ee6-09f9-4583-94fa-9b0cdedba81c.png)

## 报警规则说明 ### 基本规则 - type:可选取一个或多个类型,如在一个规则中选择了多个类型,需要**同时满足**所有选择的类型才会触发通知(可参考后面的示例) - `cpu`、`memory`、`swap`、`disk` - `net_in_speed` 入站网速、`net_out_speed` 出站网速、`net_all_speed` 双向网速、`transfer_in` 入站流量、`transfer_out` 出站流量、`transfer_all` 双向流量 - `offline` 离线监控 - `load1`、`load5`、`load15` 负载 - `process_count` 进程数 _目前取线程数占用资源太多,暂时不支持_ - `tcp_conn_count`、`udp_conn_count` 连接数 - duration:持续数秒,数秒内采样记录 30% 以上触发阈值才会报警(防数据插针) - min 或 max: - 流量、网速类数值 为字节(1KB=1024B,1MB = 1024\*1024B) - 内存、硬盘、CPU 以占用百分比计数 - 离线监控无需设置此项 - cover: - `0` 监控所有,通过 `ignore` 忽略特定服务器 - `1` 忽略所有,通过 `ignore` 监控特定服务器 例如:`[{"type":"offline","duration":10, "cover":0, "ignore":{"5": true}}]` - ignore: 选择忽略特定服务器,搭配 `cover` 使用,内容为服务器 id 和布尔值,例如:`{"1": true, "2":false}` **完整示例:** >>添加一个离线报警 > > - 名称:离线通知 > - 规则:`[{"Type":"offline","Duration":10}]` > - 启用:√ >>添加一个监控 CPU 持续 10s 超过 50% **且** 内存持续 20s 占用低于 20% 的报警 > > - 名称:CPU+内存 > - 规则:`[{"Type":"cpu","Min":0,"Max":50,"Duration":10},{"Type":"memory","Min":20,"Max":0,"Duration":20}]` > - 启用:√ >>将特定的服务器通知发送到特定的通知分组 > >示例场景: >你有 1、2、3、4 四台服务器和 A、B 两个不同的通知组 >1、2 这两台服务器掉线十分钟后给通知组 A 发送通知 >3、4 这两台服务器掉线十分钟后给通知组 B 发送通知 > >首先你需要先设置好 A、B 两个通知组,然后添加两条报警规则: > >**规则一:** > - 名称:1、2 离线,发送给通知组 A > - 规则:`[{"type":"offline","duration":600,"cover":1,"ignore":{"1":true,"2":true}}]` > - 通知方式组: A > - 启用:√ > >**规则二:** > - 名称:3、4 离线,发送给通知组 B > - 规则:`[{"type":"offline","duration":600,"cover":1,"ignore":{"3":true,"4":true}}]` > - 通知方式组: B > - 启用:√ **灵活使用参数可以让你的通知功能被充分使用**
### 特殊:任意周期流量报警 可以用作月流量报警 - type: - `transfer_in_cycle` 周期内的入站流量 - `transfer_out_cycle` 周期内的出站流量 - `transfer_all_cycle` 周期内双向流量和 - cycle_start: 统计周期开始日期(可以是你机器计费周期的开始日期),时间格式为RFC3339,例如北京时间为`2022-01-11T08:00:00.00+08:00` - cycle_interval:每隔多少个周期单位(例如,周期单位为天,该值为 7,则代表每隔 7 天统计一次) - cycle_unit 统计周期单位,默认`hour`,可选(`hour`, `day`, `week`, `month`, `year`) - min/max、cover、ignore 参考基本规则配置 >示例: >> ID 为 3 和 4 的服务器(ignore 里面定义),以每月 1 号为统计周期,周期内统计的出站月流量达到 1TB 时报警 > >`[{"type":"transfer_out_cycle","max":1099511627776,"cycle_start":"2022-01-01T00:00:00+08:00","cycle_interval":1,"cycle_unit":"month","cover":1,"ignore":{"3":true,"4":true}}]` ## 通知触发模式说明 - 始终触发:每当 Agent 上报的状态符合报警的规则时,都会触发一次通知 - 单次触发:仅状态改变时触发一次通知,如从正常状态改变为异常状态,或异常状态恢复为正常状态 ## 设置报警时执行任务 如果你需要在发出报警消息的同时执行某项任务,可以设置此项目 + `故障时触发任务` 当报警状态符合从“正常”变更为“故障”时,所要执行的任务,任务应提前在任务页设置 + `恢复时触发任务` 当报警状态符合从“故障”恢复为“正常”时,所要执行的任务,任务应提前在任务页设置