Skip to content

XksA-me/DingdingBot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

使用方法

本项目创建了一个钉钉群机器人,设置两种响应
1、每天早上9:00 发送服务器情况到钉群(包括CPU 负载 存储等数据)
2、时时预警,每30s检测一次(监控负载 CPU使用率情况,超过阀值,钉钉消息报警)

下载项目文件

# ssh下载
git clone [email protected]:XksA-me/DingdingBot.git
# https下载
git clone  https://github.com/XksA-me/DingdingBot.git
# 如果不行可以尝试下面的加速下载地址
# ssh加速地址:git clone [email protected]:XksA-me/DingdingBot.git
# https加速地址:git clone https://jackfan.us.kg.cnpmjs.org/XksA-me/DingdingBot.git

安装项目依赖第三方库

项目环境说明:

  • Python 3.6.8 (理论3.6及以上肯定可以)
  • 第三方依赖库:
    • requests 发送post请求,发送数据
    • psutil 获取操作系统运行相关数据
    • apscheduler 设置定时任务

因为相关依赖较少,你可以直接在本地环境安装使用,也可以创建一个虚拟环境安装使用(Python虚拟环境推荐使用pipenv进行管理,点击我查看pipenv使用教程)。

进入环境后,输入下面pip指令进行安装:

pip3 install requests psutil apscheduler

修改钉钉加签密钥和机器人Webhook链接

本地打开dingding_bot.py文件,然后修改第20行和第47行代码,换成你自己的钉钉加签密钥和机器人Webhook链接即可。

运行代码

项目文件夹下,直接在终端/CMD中执行下面代码即可,

python3 scheduler.py

运行效果

创建守护进程

经过上面我们完成了功能复现,但是会发现,一旦我们关闭程序,提醒监测服务也会停止,所以我们需要创建一个守护进程来保护我们的进程。

以我自己为例,我们登录宝塔面板后,进入/etc/systemd/system文件夹下,新建一个ding_bot.service文件,并写入下面内容:

[Unit]
Description=Dingding Bot service

[Service]
Type=forking
ExecStart=/usr/bin/python3 /root/Project/Little_project/DingdingBot/scheduler.py
KillMode=process
Restart=on-failure
RestartSec=3s

[Install]
WantedBy=multi-user.target

简单解释下Service里设置的含义,Type=forking表示程序启动后,会放到后台运行;ExecStart服务的具体执行指令(执行scheduler.py文件即可);KillMode=process表示服务停止的同时也会杀死程序主进程;Restart=on-failure表示系统发生意外导致程序退出时,程序自动重启。

保存好文件后,我们直接终端内执行下面指令即可开启进程守护,运行后会进入守护进程状态,我们可以按ctrl+c退出,不会影响守护进程:

systemctl start ding_bot

代码修改后,需要重启守护进程,修改代码才会生效,重启指令如下:

systemctl restart ding_bot

如果不想设置这个守护进程了,执行stop指令可以停止该service(程序也会停止),指令如下:

systemctl stop ding_bot

关于守护进程system其他的相关指令和操作可以自行搜查哈,也可以留言区交流,展开讲又是一篇推文啦~

本项目完整教程:如何用Python发送告警通知到钉钉?

我的个人网站:https://python-brief.com

我是老表,爱猫爱技术。

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages