“Python监控今测状态并实现告警”的版本间的差异
来自CloudWiki
(→Python监控进程状态并实现告警) |
(→Python监控进程状态并实现告警) |
||
第33行: | 第33行: | ||
首先我们先定义一个proc_exist函数,函数的第一个参数传入进程名, 中pl =sutil.pids()示把所有的进程列出来。接着我们for循环一下pid的列表,当找到psutil. Process(pid) .name()的名词为传入的参数的名字的时候就返回pid 值,没有就不做任何操作(可以认为返回内容为空)接着isinstance用于检测返回内容。 | 首先我们先定义一个proc_exist函数,函数的第一个参数传入进程名, 中pl =sutil.pids()示把所有的进程列出来。接着我们for循环一下pid的列表,当找到psutil. Process(pid) .name()的名词为传入的参数的名字的时候就返回pid 值,没有就不做任何操作(可以认为返回内容为空)接着isinstance用于检测返回内容。 | ||
− | 上面可以进行进程检测了,我们实现发送邮箱代码实现: | + | 上面可以进行进程检测了,我们实现发送邮箱代码实现:<br> |
− | (通过多次实验发现,需要先获取对于的SMTP邮箱授权码,我这里使用的163邮箱) | + | '''(通过多次实验发现,需要先获取对于的SMTP邮箱授权码,我这里使用的163邮箱)''' |
[[文件:2020-08-09 094100.png]] | [[文件:2020-08-09 094100.png]] | ||
+ | |||
+ | Python代码: | ||
+ | #coding:utf-8 | ||
+ | import smtplib | ||
+ | from email.mime.text import MIMEText | ||
+ | class SendEMail(object): | ||
+ | # 定义第三方 SMTP 服务 | ||
+ | def __init__(self): | ||
+ | self.mail_host = "smtp.163.com" # SMTP服务器 | ||
+ | self.mail_user = "15610347662@163.com" # 用户名 | ||
+ | self.mail_pass = "APLL" # 密码 | ||
+ | self.sender = '15610347662@163.com' # 发件人邮箱 | ||
+ | self.smtpObj = smtplib.SMTP_SSL(self.mail_host, 465) | ||
+ | self.smtpObj.login(self.mail_user, self.mail_pass) # 登录验证 | ||
+ | def sendmail(self, receivers, title, content): | ||
+ | message = MIMEText(content, 'plain', 'utf-8') # 内容, 格式, 编码 | ||
+ | message['From'] = "{}".format(self.sender) | ||
+ | message['To'] = ",".join(receivers) | ||
+ | message['Subject'] = title | ||
+ | try: | ||
+ | self.smtpObj.sendmail(self.sender, message['To'].split(','), message.as_string()) # 发送 | ||
+ | print("mail has been send successfully.") | ||
+ | except smtplib.SMTPException as e: | ||
+ | print(e) | ||
+ | if __name__ == '__main__': | ||
+ | sm = SendEMail() | ||
+ | sm.sendmail(['15610347662@163.com'], 'Python测试邮箱', '人生苦短') |
2020年8月9日 (日) 02:09的版本
Python监控进程状态并实现告警
公司的Java应用程序会莫名其妙的挂掉,然后我们再去登录服务器看看程序是不是挂掉了,这样是非常耗时间麻烦的事,这种情况和什么行业没有直接联系但却普遍存在。后来我们可以使用supervisor进行守护进程。
Supervisor用Python开发的一个client/server服务,是Linux/Unix系统 下的一个进程管理工具,不支持Windows系统。它可以很方便地监听、启动、停止、重劃-个或多个进程。用Supervisor管理的进程, 当-个进程意外被杀死,或者是意外被停止(系统负载过高,cpu 占用率很等),supervisor 监听到进程死后,自动将它重新拉起来,很方便地做到进程自动恢复的功能,不再需要自己写shel脚本来控制。
通过Python代码实现
第一步:我们首先判断进程是否存在的逻辑,采用psutil来实现,先安装库
pip3 install psutil
进程检测实现代码如下:
#coding:utf-8 import psutil def proc_exist(process_name): pl = psutil.pids() for pid in pl: if psutil.Process(pid).name() == process_name: return pid if isinstance(proc_exist('sshdd'),int): print('进程存在') else: print('进程不存在')
运行代码我们这里检测ssh服务是否开启:
代码解析: 解析: . 首先我们先定义一个proc_exist函数,函数的第一个参数传入进程名, 中pl =sutil.pids()示把所有的进程列出来。接着我们for循环一下pid的列表,当找到psutil. Process(pid) .name()的名词为传入的参数的名字的时候就返回pid 值,没有就不做任何操作(可以认为返回内容为空)接着isinstance用于检测返回内容。
上面可以进行进程检测了,我们实现发送邮箱代码实现:
(通过多次实验发现,需要先获取对于的SMTP邮箱授权码,我这里使用的163邮箱)
Python代码:
#coding:utf-8 import smtplib from email.mime.text import MIMEText class SendEMail(object): # 定义第三方 SMTP 服务 def __init__(self): self.mail_host = "smtp.163.com" # SMTP服务器 self.mail_user = "15610347662@163.com" # 用户名 self.mail_pass = "APLL" # 密码 self.sender = '15610347662@163.com' # 发件人邮箱 self.smtpObj = smtplib.SMTP_SSL(self.mail_host, 465) self.smtpObj.login(self.mail_user, self.mail_pass) # 登录验证 def sendmail(self, receivers, title, content): message = MIMEText(content, 'plain', 'utf-8') # 内容, 格式, 编码 message['From'] = "{}".format(self.sender) message['To'] = ",".join(receivers) message['Subject'] = title try: self.smtpObj.sendmail(self.sender, message['To'].split(','), message.as_string()) # 发送 print("mail has been send successfully.") except smtplib.SMTPException as e: print(e) if __name__ == '__main__': sm = SendEMail() sm.sendmail(['15610347662@163.com'], 'Python测试邮箱', '人生苦短')