nezha/README.md

388 lines
15 KiB
Markdown
Raw Normal View History

2021-09-27 09:18:09 -04:00
<div align="center">
2021-08-04 01:52:47 -04:00
<br>
<img width="250" style="max-width:80%" src="resource/static/brand.svg" title="哪吒监控">
<br>
<small><i>LOGO designed by <a href="https://xio.ng" target="_blank">熊大</a> .</i></small>
<br><br>
<img src="https://img.shields.io/github/workflow/status/naiba/nezha/Dashboard%20image?label=Dash%20v0.12.0&logo=github&style=for-the-badge">&nbsp;<img src="https://img.shields.io/github/v/release/naiba/nezha?color=brightgreen&label=Agent&style=for-the-badge&logo=github">&nbsp;<img src="https://img.shields.io/github/workflow/status/naiba/nezha/Agent%20release?label=Agent%20CI&logo=github&style=for-the-badge">&nbsp;<img src="https://img.shields.io/badge/Installer-v0.8.0-brightgreen?style=for-the-badge&logo=linux">
2021-03-20 23:24:02 -04:00
<br>
<br>
<p>:trollface: <b>哪吒监控</b> 一站式轻监控轻运维系统。支持系统状态、HTTP(SSL 证书变更、即将到期、到期)、TCP、Ping 监控报警,计划任务和在线终端。</p>
2021-03-20 23:20:54 -04:00
</div>
\>> QQ 交流群872069346 **加群要求:已搭建好哪吒监控 & 有 2+ 服务器**
2021-02-06 20:53:12 -05:00
2021-06-24 00:22:53 -04:00
\>> [我们的用户](https://www.google.com/search?q="powered+by+哪吒监控"&filter=0) (Google)
| 默认主题 | DayNight [@JackieSung](https://github.com/JackieSung4ev) | hotaru |
| ---------------------------------------------------------------------------------------- | ------------------------------------------------------------ | -------------------------------------------------------------------------- |
| ![默认主题](resource/template/theme-default/screenshot.png) | ![daynight](resource/template/theme-daynight/screenshot.png) | <img src="resource/template/theme-hotaru/screenshot.png" width="1600px" /> |
| <div align="center"><b>默认主题魔改 <a href="https://ii.do/43.html">[教程]</a></b></div> | | |
| ![默认主题魔改](https://cdn.jsdelivr.net/gh/idarku/img@main/me/1631120192341.webp) | | |
2020-12-19 05:38:28 -05:00
## 安装脚本
2020-11-06 07:51:23 -05:00
2021-09-27 09:18:09 -04:00
**推荐配置:** 安装前准备 _两个域名_,一个可以 **接入 CDN** 作为 _公开访问_,比如 (status.nai.ba);另外一个解析到面板服务器作为 Agent 连接 Dashboard 使用,**不能接入 CDN** 直接暴露面板主机 IP比如ip-to-dashboard.nai.ba
```shell
2021-05-26 11:00:35 -04:00
curl -L https://raw.githubusercontent.com/naiba/nezha/master/script/install.sh -o nezha.sh && chmod +x nezha.sh
sudo ./nezha.sh
```
2021-01-16 08:41:31 -05:00
2021-04-06 06:06:46 -04:00
国内镜像加速:
2020-12-18 21:57:10 -05:00
```shell
2021-05-26 11:00:35 -04:00
curl -L https://cdn.jsdelivr.net/gh/naiba/nezha@master/script/install.sh -o nezha.sh && chmod +x nezha.sh
CN=true sudo ./nezha.sh
```
2021-02-12 20:42:21 -05:00
_\* 使用 WatchTower 可以自动更新面板Windows 终端可以使用 nssm 配置自启动见尾部教程_
### 增强配置
2021-09-27 09:18:09 -04:00
通过执行 `./nezha-agent --help` 查看支持的参数,如果你使用一键脚本,可以编辑 `/etc/systemd/system/nezha-agent.service`,在 `ExecStart=` 这一行的末尾加上
2021-09-27 09:18:09 -04:00
- `--report-delay` 系统信息上报的间隔,默认为 1 秒,可以设置为 3 来进一步降低 agent 端系统资源占用(配置区间 1-4
- `--skip-conn` 不监控连接数,机场/连接密集型机器推荐设置,不然比较占 CPU([shirou/gopsutil/issues#220](https://github.com/shirou/gopsutil/issues/220))
- `--skip-procs` 不监控进程数,也可以降低 agent 占用
2021-11-04 00:06:20 -04:00
- `--disable-auto-update` 禁止 **自动更新** Agent安全特性
- `--disable-force-update` 禁止 **强制更新** Agent安全特性
- `--disable-command-execute` 禁止在 Agent 机器上执行定时任务、打开在线终端(安全特性)
- `--tls` 启用SSL/TLS加密使用 nginx 反向代理 Agent 的 grpc 连接,并且 nginx 开启 SSL/TLS 时,需要启用该项配置)
2021-09-27 09:18:09 -04:00
## 功能说明
2020-12-18 21:57:10 -05:00
<details>
<summary>计划任务:备份脚本、服务重启,等定期运维任务。</summary>
使用此功能可以定期结合 restic、rclone 给服务器备份,或者定期某项重启服务来重置网络连接。
2021-02-01 08:32:20 -05:00
</details>
2020-12-19 23:18:27 -05:00
2021-01-16 08:41:31 -05:00
<details>
2021-08-15 04:40:52 -04:00
<summary>报警通知负载、CPU、内存、硬盘、带宽、流量、月流量、进程数、连接数实时监控。</summary>
2020-12-30 00:51:42 -05:00
#### 灵活通知方式
2020-12-30 08:28:57 -05:00
`#NEZHA#` 是面板消息占位符,面板触发通知时会自动替换占位符到实际消息
2020-12-30 00:51:42 -05:00
2021-02-01 08:32:20 -05:00
Body 内容是`JSON` 格式的:**当请求类型为 FORM 时**,值为 `key:value` 的形式,`value` 里面可放置占位符,通知时会自动替换。**当请求类型为 JSON 时** 只会简进行字符串替换后直接提交到`URL`。
2020-12-30 08:28:57 -05:00
URL 里面也可放置占位符,请求时会进行简单的字符串替换。
2020-12-30 00:51:42 -05:00
参考下方的示例,非常灵活。
2020-12-19 23:18:27 -05:00
1. 添加通知方式
2021-02-01 08:32:20 -05:00
- server 酱示例
2021-02-01 08:32:20 -05:00
- 名称server 酱
2021-09-27 09:18:09 -04:00
- URL<https://sc.ftqq.com/SCUrandomkeys.send?text=#NEZHA>#
2021-02-01 08:32:20 -05:00
- 请求方式: GET
- 请求类型: 默认
- Body: 空
2021-02-01 08:32:20 -05:00
- wxpusher 示例,需要关注你的应用
- 名称: wxpusher
2021-09-27 09:18:09 -04:00
- URL<http://wxpusher.zjiecode.com/api/send/message>
2021-02-01 08:32:20 -05:00
- 请求方式: POST
- 请求类型: JSON
- Body: `{"appToken":"你的appToken","topicIds":[],"content":"#NEZHA#","contentType":"1","uids":["你的uid"]}`
- telegram 示例 [@haitau](https://github.com/haitau) 贡献
2021-02-01 08:32:20 -05:00
- 名称telegram 机器人消息通知
2021-09-27 09:18:09 -04:00
- URL<https://api.telegram.org/botXXXXXX/sendMessage?chat_id=YYYYYY&text=#NEZHA>#
2021-02-01 08:32:20 -05:00
- 请求方式: 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 对话可获得。
2021-01-08 05:28:55 -05:00
2020-12-19 23:18:27 -05:00
2. 添加一个离线报警
2021-02-01 08:32:20 -05:00
- 名称:离线通知
2021-02-12 20:42:21 -05:00
- 规则:`[{"Type":"offline","Duration":10}]`
2021-02-01 08:32:20 -05:00
- 启用:√
2020-12-19 23:18:27 -05:00
3. 添加一个监控 CPU 持续 10s 超过 50% **且** 内存持续 20s 占用低于 20% 的报警
2021-02-01 08:32:20 -05:00
- 名称CPU+内存
- 规则:`[{"Type":"cpu","Min":0,"Max":50,"Duration":10},{"Type":"memory","Min":20,"Max":0,"Duration":20}]`
- 启用:√
2020-12-19 23:18:27 -05:00
#### 报警规则说明
##### 基本规则
- type
- `cpu`、`memory`、`swap`、`disk`
- `net_in_speed` 入站网速、`net_out_speed` 出站网速、`net_all_speed` 双向网速、`transfer_in` 入站流量、`transfer_out` 出站流量、`transfer_all` 双向流量
- `offline` 离线监控
- `load1`、`load5`、`load15` 负载
2021-08-27 08:30:36 -04:00
- `process_count` 进程数 _目前取线程数占用资源太多暂时不支持_
2021-08-15 04:40:52 -04:00
- `tcp_conn_count`、`udp_conn_count` 连接数
- duration持续秒数秒数内采样记录 30% 以上触发阈值才会报警(防数据插针)
- min/max
2021-07-15 23:19:51 -04:00
- 流量、网速类数值 为字节1KB=1024B1MB = 1024\*1024B
- 内存、硬盘、CPU 为占用百分比
- 离线监控无需设置
- cover `[{"type":"offline","duration":10, "cover":0, "ignore":{"5": true}}]`
- `0` 监控所有,通过 `ignore` 忽略特定服务器
- `1` 忽略所有,通过 `ignore` 监控特定服务器
- ignore: `{"1": true, "2":false}` 特定服务器,搭配 `cover` 使用
##### 特殊:任意周期流量报警
可以用作月流量报警
- type
- transfer_in_cycle 周期内的入站流量
- transfer_out_cycle 周期内的出站流量
- transfer_all_cycle 周期内双向流量和
- cycle_start 周期开始日期(可以是你机器计费周期的开始日期)
2021-08-03 10:10:55 -04:00
- cycle_interval 小时(可以设为 1 月30\*24
- min/max、cover、ignore 参考基本规则配置
2021-11-07 20:59:52 -05:00
- 示例: ID 为 3 的机器ignore 里面定义)的每月 15 号计费的出站月流量 1T 报警 `[{"type":"transfer_out_cycle","max":1000000000000,"cycle_start":"2021-07-15T08:00:00Z","cycle_interval":730,"cover":1,"ignore":{"3":true}}]`
2021-09-27 09:18:09 -04:00
2021-01-16 08:41:31 -05:00
</details>
2021-01-16 22:59:58 -05:00
<details>
<summary>服务监控HTTP、SSL证书、ping、TCP 端口等。</summary>
2021-09-02 11:46:10 -04:00
进入 `/monitor` 页面点击新建监控即可,表单下面有相关说明。
2021-02-01 08:32:20 -05:00
2021-01-16 22:59:58 -05:00
</details>
2021-01-16 08:41:31 -05:00
<details>
<summary>自定义代码改LOGO、改色调、加统计代码等。</summary>
- 默认主题更改进度条颜色示例
```
<style>
.ui.fine.progress> .bar {
background-color: pink !important;
}
</style>
```
- DayNight 主题更改进度条颜色、修改页脚示例(来自 [@hyt-allen-xu](https://github.com/hyt-allen-xu)
2021-04-28 00:38:29 -04:00
```
<style>
.ui.fine.progress> .progress-bar {
background-color: #00a7d0 !important;
}
</style>
<script>
window.onload = function(){
var footer=document.querySelector("div.footer-container")
footer.innerHTML="©2021 你的名字 & Powered by 你的名字"
footer.style.visibility="visible"
}
</script>
2021-04-28 00:38:29 -04:00
```
- 默认主题修改 LOGO、修改页脚示例来自 [@iLay1678](https://github.com/iLay1678)
```
<style>
.right.menu>a{
visibility: hidden;
}
.footer .is-size-7{
visibility: hidden;
}
.item img{
visibility: hidden;
}
</style>
<script>
window.onload = function(){
var avatar=document.querySelector(".item img")
var footer=document.querySelector("div.is-size-7")
footer.innerHTML="Powered by 你的名字"
footer.style.visibility="visible"
avatar.src="你的方形logo地址"
avatar.style.visibility="visible"
}
</script>
```
- hotaru 主题更改背景图片示例
2021-05-09 11:42:24 -04:00
```
<style>
.hotaru-cover {
background: url(https://s3.ax1x.com/2020/12/08/DzHv6A.jpg) center;
}
</style>
```
</details>
2020-12-07 21:38:45 -05:00
## 常见问题
2021-01-16 08:41:31 -05:00
<details>
2021-01-25 20:16:34 -05:00
<summary>如何进行数据迁移、备份恢复?</summary>
2020-12-07 21:38:45 -05:00
2021-10-31 04:14:23 -04:00
1. 先使用一键脚本 `停止面板`
2. 打包 `/opt/nezha` 文件夹,到新环境相同位置
3. 使用一键脚本 `启动面板`
2021-02-01 08:32:20 -05:00
2021-01-16 08:41:31 -05:00
</details>
<details>
<summary>Agent 启动/上线 问题自检流程</summary>
1. 直接执行 `/opt/nezha/agent/nezha-agent -s 面板IP或非CDN域名:面板RPC端口 -p Agent密钥 -d` 查看日志是否是 DNS、网络不佳导致超时timeout 问题。
2021-09-27 09:18:09 -04:00
2. `nc -v 域名/IP 面板RPC端口` 或者 `telnet 域名/IP 面板RPC端口` 检验是否是网络问题,检查本机与面板服务器出入站防火墙,如果单机无法判断可借助 <https://port.ping.pe/> 提供的端口检查工具进行检测。
2021-08-10 11:48:26 -04:00
3. 如果上面步骤检测正常Agent 正常上线,尝试关闭 SELinux[如何关闭 SELinux](https://www.google.com/search?q=%E5%85%B3%E9%97%ADSELINUX)
2021-09-27 09:18:09 -04:00
</details>
<details>
2021-01-25 20:16:34 -05:00
<summary>如何使 OpenWrt/LEDE 自启动?来自 @艾斯德斯</summary>
首先在 release 下载对应的二进制解压 tar.gz 包后放置到 `/root`,然后 `chmod +x /root/nezha-agent` 赋予执行权限,然后创建 `/etc/init.d/nezha-service`
```shell
#!/bin/sh /etc/rc.common
START=99
2021-01-29 01:29:31 -05:00
USE_PROCD=1
2021-01-29 01:29:31 -05:00
start_service() {
2021-09-27 09:18:09 -04:00
procd_open_instance
procd_set_param command /root/nezha-agent -s 面板网址:接收端口 -p 唯一秘钥 -d
procd_set_param respawn
procd_close_instance
}
2021-01-29 01:29:31 -05:00
stop_service() {
killall nezha-agent
}
2021-01-29 01:29:31 -05:00
restart() {
2021-09-27 09:18:09 -04:00
stop
sleep 2
start
}
```
2021-05-26 08:18:56 -04:00
赋予执行权限 `chmod +x /etc/init.d/nezha-service` 然后启动服务 `/etc/init.d/nezha-service enable && /etc/init.d/nezha-service start`
2021-02-01 08:32:20 -05:00
</details>
2021-01-16 08:41:31 -05:00
<details>
<summary>实时通道断开/在线终端连接失败</summary>
使用反向代理时需要针对 `/ws`,`/terminal` 路径的 WebSocket 进行特别配置以支持实时更新服务器状态和 **WebSSH**
2020-12-01 21:04:06 -05:00
2020-12-01 22:46:31 -05:00
- Nginx(宝塔):在你的 nginx 配置文件中加入以下代码
2020-12-01 21:04:06 -05:00
2021-02-01 08:32:20 -05:00
```nginx
server{
2020-12-01 21:04:06 -05:00
#原有的一些配置
2021-02-01 08:32:20 -05:00
#server_name blablabla...
2020-11-06 07:51:23 -05:00
location ~ ^/(ws|terminal/.+)$ {
2021-02-01 08:32:20 -05:00
proxy_pass http://ip:站点访问端口;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
proxy_set_header Host $host;
}
2020-12-01 21:04:06 -05:00
2021-02-01 08:32:20 -05:00
#其他的 location blablabla...
}
```
2020-12-01 21:04:06 -05:00
如果非宝塔,还要在 `server{}` 中添加上这一段
```nginx
location / {
proxy_pass http://ip:站点访问端口;
proxy_set_header Host $host;
}
```
2021-02-01 08:32:20 -05:00
- CaddyServer v1v2 无需特别配置)
2020-12-01 21:04:06 -05:00
2021-02-12 20:42:21 -05:00
```Caddyfile
proxy /ws http://ip:8008 {
websocket
}
2021-08-18 21:26:57 -04:00
proxy /terminal/* http://ip:8008 {
websocket
}
2021-02-12 20:42:21 -05:00
```
2021-02-01 08:32:20 -05:00
</details>
2020-11-06 07:51:23 -05:00
<details>
<summary>反向代理 gRPC 端口(支持 Cloudflare CDN</summary>
使用 Nginx 或者 Caddy 反向代理 gRPC
- Nginx 配置
2021-11-07 20:59:52 -05:00
```nginx
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name ip-to-dashboard.nai.ba; # 你的 Agent 连接 Dashboard 的域名
ssl_certificate /data/letsencrypt/fullchain.pem; # 你的域名证书路径
ssl_certificate_key /data/letsencrypt/key.pem; # 你的域名私钥路径
underscores_in_headers on;
location / {
grpc_read_timeout 300s;
grpc_send_timeout 300s;
grpc_pass grpc://localhost:5555;
}
}
```
2021-11-07 20:59:52 -05:00
- Caddy 配置
2021-11-07 20:59:52 -05:00
```Caddyfile
ip-to-dashboard.nai.ba:443 { # 你的 Agent 连接 Dashboard 的域名
reverse_proxy {
to localhost:5555
transport http {
versions h2c 2
}
}
}
```
2021-11-07 20:59:52 -05:00
Dashboard 面板端配置
- 首先登录面板进入管理后台 打开设置页面,在 `未接入CDN的面板服务器域名/IP` 中填入上一步在 Nginx 或 Caddy 中配置的域名 比如 `ip-to-dashboard.nai.ba` ,并保存。
- 然后在面板服务器中,打开 /opt/nezha/dashboard/data/config.yaml 文件,将 `proxygrpcport` 修改为 Nginx 或 Caddy 监听的端口,比如上一步设置的 `443` ;因为我们在 Nginx 或 Caddy 中开启了 SSL/TLS所以需要将 `tls` 设置为 `true` ;修改完成后重启面板。
Agent 端配置
- 登录面板管理后台,复制一键安装命令,在对应的服务器上面执行一键安装命令重新安装 agent 端即可。
开启 Cloudflare CDN可选
根据 Cloudflare gRPC 的要求gRPC 服务必须侦听 443 端口 且必须支持 TLS 和 HTTP/2。
所以如果需要开启CDN必须在配置 Nginx 或者 Caddy 反向代理 gRPC 时使用 443 端口并配置证书Caddy 会自动申请并配置证书)。
- 登录 Cloudflare选择使用的域名。打开 `网络` 选项将 `gRPC` 开关打开,打开 `DNS` 选项,找到 Nginx 或 Caddy 反代 gRPC 配置的域名的解析记录打开橙色云启用CDN。
2021-11-07 20:59:52 -05:00
2021-11-06 01:03:56 -04:00
</details>
2020-11-29 09:17:40 -05:00
## 社区文章
2020-11-06 07:51:23 -05:00
2020-12-19 03:29:57 -05:00
- [哪吒探针 - Windows 客户端安装](https://nyko.me/2020/12/13/nezha-windows-client.html)
- [哪吒监控,一个便携服务器状态监控面板搭建教程,不想拥有一个自己的探针吗?](https://haoduck.com/644.html)
- [哪吒监控:小鸡们的最佳探针](https://www.zhujizixun.com/2843.html) _已过时_
2021-06-24 00:22:53 -04:00
- [>>更多教程](https://www.google.com/search?q="哪吒监控"+"教程") (Google)
2021-09-02 01:39:30 -04:00
SEO **云探针、多服务器探针、云监控、多服务器云监控**