动态获取脚本进程pid进程号,linux 查看python脚本状态,通过os模块获取任意脚本pid进程号,再通过psutil包获取当前脚本运行状态,并输出日志

首先要安装

pip install psutil 
# psutil这个包是第三方包需要自己安装

判断CPU状态

#!/usr/bin/python3
# 这次是监视单个进程所占CPU的资源百分比,上一个版本是判断整个树莓派CPU占
#用率,这个虽然能实现功能,但是存在风险,有些情况下不是我写的脚本所引起的
#整个树莓派CPU占用率过高就,进行重启程序。


import psutil as p
import os
import logging

logging.basicConfig(level=logging.DEBUG,
                    filename='thread_cpu_log1.0.log',
                    filemode='a',
                    format=
                    '%(asctime)s - %(pathname)s[line:%(lineno)d] - %(levelname)s: %(message)s')
                    #filename='/home/pi/Desktop/thread_cpu_log1.0.log',是linux操作目录你可以写成当前目录下
try:
    pid1 = os.popen( 'ps -ef | grep threading_modbus_16_005.py | grep -v "grep"') #获取整个进程的状态,在第一个grep 后输入的是你python脚本的名称
    pid2 = pid1.read()[11:14]  # 字符串截取获取当前进程的pid 也就是进程号
    # 接下来通过进程号获取 当前进程号 的状态
    pid_cpu = p.Process(int(pid2)).cpu_percent() #创建对象并获取占用CPU

    if pid_cpu > 100:
        logging.debug('重启一次')
        os.system('sudo reboot')
    else:
        logging.debug('正常')
except:
    logging.debug("所查询进程进程没启动")
# os模块的使用
os.system()  #python环境执行linux命令 返回值 只有 0,1,2
os.popen()  #管道的作用是有返回值得同 执行linux命令后得到的返回值相同, #是字符串类型,获取想要的变量需要切片
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章