当前位置:首页 > 教程 > 正文内容

哪吒探针安装(在线版)

admin2年前 (2023-07-23)教程5832

哪吒面板作者仓库
https://github.com/naiba/nezha

准备工作
准备一个域名
注册一个github的账户
准备一条vps作为面板机器,并搭建好宝塔面板。

1、安装宝塔
wget -O install.sh http://download.bt.cn/install/install-ubuntu_6.0.sh && bash install.sh

2解析域名,例如 vps.domain.com 和 88.domain.com 都A指向到面板IP(解析两个域名作用:如果你不需要cdf代理的话,解析一个就够了,如果需要cf代理的话需要解析一个不代理的域名,比如88那个用来客户端输入)

3 注册github

创建一个OAuth Apps,
打开:
https://github.com/settings/developers 然后点击New OAuth App按钮,填入你第一个域名

https://你的域名
https://你的域名/oauth2/callback
输入完成后,能看到OAuth Apps的Client ID和Client secrets两个数值,(其中Client secrets需要自己创建一下)保存下来。

4、部署面板
国外机

curl -L https://raw.githubusercontent.com/naiba/nezha/master/script/install.sh -o nezha.sh && chmod +x nezha.sh && ./nezha.sh
国内机

curl -L https://raw.sevencdn.com/naiba/nezha/master/script/install.sh -o nezha.sh && chmod +x nezha.sh && ./nezha.sh
选择1开始安装面板
所涉及到的数值,前面都有提到。

进入服务器宝塔后台,创建一个站点,用你带套的那个域名。
然后网站设置,添加反向代理

  • 自定义一个代理名称,在下方“目标 URL”中填入 http://127.0.0.1 然后点击“保存”

  • 打开刚刚新建的反向代理右边的“配置文件”,将配置文件替换为以下内容:

#PROXY-START/
location /
{

proxy_pass http://127.0.0.1:8008;
proxy_set_header Host $host;
}
location /ws
{

proxy_pass http://127.0.0.1:8008;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
proxy_set_header Host $host;
}
#如果像不需要远程ssh把这下面的不要复制
location /terminal
{
proxy_pass http://127.0.0.1:8008;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
proxy_set_header Host $host;
}
#PROXY-END/



点击“保存”
现在,你应该可以直接使用域名,如:“http://cdn.example.com“ 来访问面板了


还有一种方法,如果你只是停止某一个服务器停止ssh你可以单独修改某一台服务器的停止ssh,安装好之后运行:

sed -i 's/\/opt\/nezha\/agent\/nezha-agent/\/opt\/nezha\/agent\/nezha-agent\ --disable-command-execute/' /etc/systemd/system/nezha-agent.service
systemctl daemon-reload
service nezha-agent restart
service nezha-agent status

上述代码意思停止本台服务器的ssh功能


5.被控机的安装
登陆面板机后台,添加一个主机,会生成秘钥,然后在被控机上输入代码(其实和安装主控的代码是一样的)
国外机

curl -L  https://raw.githubusercontent.com/naiba/nezha/master/script/install.sh -o nezha.sh && chmod +x nezha.sh && ./nezha.sh


国内机

curl -L https://raw.sevencdn.com/naiba/nezha/master/script/install.sh -o nezha.sh && chmod +x nezha.sh && ./nezha.sh


选择8,然后第一个输入你刚才不带套的那个域名(88那个),端口默认,秘钥就是刚才添加主机时的那个秘钥,输入网址的时候记得不带http

还有一种方法就是后台设置里把你的网址输入进去,会总动生成客户的代码,不用输入信息等等

6.TG机器人设置
先申请一个机器人 @Botfather ,然后/newbot ,创建新的机器人(bot)时,会提供的 token(在提示 Use this token to access the HTTP API:后面一行)这里 'bot' 三个字母不可少;然后获取自己TG的数字Id, 和这个机器人 @userinfobot 对话可获得一串数字;这两个保存下来,一会备用。

进入面板机后台,报警——先添加通知方式,格式为

https://api.telegram.org/botXXXXXX/sendMessage?chat_id=YYYYYY&text=#NEZHA#
其中bot后面的XXX为机器人的token,chat_id为你自己TG的ID。

然后添加报警规则,常用的离线规则为

[{"Type":"offline","Duration":30}]

设置后记得设为启动就行。更多类似于监控cpu、内存报警等等,就查看作者仓库吧~

通知教程:

灵活的通知方式

#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 酱进阶

{
 "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)"
}


  • wxpusher 示例,需要关注你的应用

  • Telegram 示例 贡献者:@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 贡献者:@白歌
    注意:SendCloud 有每日免费发送邮件限额限制,这里仅作示例,你可以选择付费服务或其他类似的免费服务,使用方法类似。

    URL 参数获取说明:此方式需提前在 SendCloud 注册账号,创建发件邮箱,然后在这里获取 APIUSER 和 APIKEY,替换 URL 中的 <替换APIUSER> 和 <替换APIKEY> 为自己的 APIUSER 和 APIKEY,替换 URL 中的 <自定义发件邮箱> 和 <自定义收件邮箱> 为自己的发件邮箱和收件邮箱。

    • 名称:邮件告警

    • 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: 留空


企业微信 群机器人 示例 贡献者:@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",  # 无效}

群机器人配置说明 - 文档 - 企业微信开发者中心

  • 名称:企业微信群机器人

  • 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"    }}

    根据需求删减相关内容信息即可


报警规则说明

基本规则

  • type:可选取一个或多个类型,如在一个规则中选择了多个类型,需要同时满足所有选择的类型才会触发通知(可参考后面的示例)

    • cpumemoryswapdisk

    • net_in_speed 入站网速、net_out_speed 出站网速、net_all_speed 双向网速、transfer_in 入站流量、transfer_out 出站流量、transfer_all 双向流量

    • offline 离线监控

    • load1load5load15 负载

    • process_count 进程数 目前取线程数占用资源太多,暂时不支持

    • tcp_conn_countudp_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,可选(hourdayweekmonthyear)

  • 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 上报的状态符合报警的规则时,都会触发一次通知

  • 单次触发:仅状态改变时触发一次通知,如从正常状态改变为异常状态,或异常状态恢复为正常状态

设置报警时执行任务

如果你需要在发出报警消息的同时执行某项任务,可以设置此项目

  • 故障时触发任务 当报警状态符合从“正常”变更为“故障”时,所要执行的任务,任务应提前在任务页设置

  • 恢复时触发任务 当报警状态符合从“故障”恢复为“正常”时,所要执行的任务,任务应提前在任务页设置



扫描二维码推送至手机访问。

版权声明:本文由Cale-Blog发布,如需转载请注明出处。

本文链接:https://blog.yidecloud.top/?id=20

分享给朋友:

“哪吒探针安装(在线版)” 的相关文章

关于终端提交高斯教程

现对两台linux服务器终端(远程)递交任务方式进行说明:1 终端SSH软件安装根据自己的喜好安装适合自己的SSH终端软件(温馨提示:下载软件请到官网下载),本人推荐带有FTP服务的ssh终端软件如:MobaXterm、WindTerm等,或者Putty等2 地址用户名和密码2.1 局域网Gauss...

傻妞更新最新版后配置redis问题集锦

傻妞更新最新版后配置redis问题集锦

题前话:更新配置前,一定要进入etc/sillyGirl文件夹备份sillyGirl.cache文件,非常重要,一定要备份,当时更新出问题,重装时,直接把这个 cache文件上传替换重启,傻妞的所有配置参数就又回来了,非常重要哈,一定要备份。sillyGirl.cache文件备份后,傻妞更新到最新版...

CentOS7服务器(监测CPU,内存,磁盘,nginx,php服务)监控+邮件告警脚本

1、安装mailx通过yum安装postfix的产生是为了替代传统的sendmail.相较于sendmail,postfix在速度。性能和稳定性上都更胜一筹,由于linux中自带了postfix,为了postfix和sendmail两者间不产生冲突,需要切换MTA(mail transter age...

Bilibili之cookie

Bilibili之cookie

一 打开B站网站https://www.bilibili.com/,二 打开F12,工程工具三 扫码登陆网络-nav-cookie...

汉化版本Aarpl-i18n引导安装黑群晖7.2

汉化版本Aarpl-i18n引导安装黑群晖7.2

1 引导文件下载第一个是原版大神的地址:https://github.com/fbelavenuto/arpl 第二个是国内ing大神修改的地址:https://github.com/wjz304/arpl-i18n 2 下载选项说明实体机选在下载img的固件,然后使用写入软件比如ImageWrit...

无界bncr搭建

无界bncr搭建

1  安装无界 关注机器人https://t.me/red_Lights_Districts_Bot 进群https://t.me/BncrJSChat发送/get_token2 docker部署# 在你要存放数据的目录下手动新建BncrData文件夹# (以root目录为例)...