本文实例为大家分享了python监控进程脚本的具体代码,供大家参考,具体内容如下
原理:
监控一个指定进程,每隔5秒钟获取其CPU、内存使用量超过60%即kill掉该进程,获取其句柄数,超过300也kill掉该进程
运行环境是windows 64位系统+python 2.7 64位 ,这里需要使用到psutil 类库,要另外安装。脚本里面可以自动安装,前提是你已经下载好了安装包psutil-3.3.0.win-amd64-py2.7.exe
下面看代码:
#!/usr/bin/env python # -*- coding:utf-8 -*- import time from datetime import date, datetime, timedelta import platform import os import win32ui,win32api,win32con,win32gui import subprocess def install(): print("install psutil...") sysstr = platform.system() if(sysstr =="Windows"): print ("Call Windows tasks") bit,type=platform.architecture() print ("os bit: %s " % bit) #print ("os type: %s " % type) if(bit == "64bit"): fileName="psutil-3.3.0.win-amd64-py2.7.exe"; else: fileName="psutil-3.3.0.win32-py2.7.exe"; print("will install the file [%s]" % fileName) #启动程序--4种方法 #subprocess.Popen(fileName); #非阻塞 #subprocess.Popen(fileName).wati(); #阻塞 #os.system(fileName); #阻塞 #win32api.ShellExecute(0, 'open', fileName, '','',0) label = 'Setup' #此处假设主窗口名为tt hld = win32gui.FindWindow(None, label) count=0 while (hld == 0 and count<20): print("the setup is no running,will run it...") count += 1 win32api.ShellExecute(0, 'open', fileName, '','',0) print("sleep 1 seconds...") time.sleep(0.5) #wnd = win32ui.GetForegroundWindow() #print wnd.GetWindowText() hld = win32gui.FindWindow(None, label) print("hld is %s" % hld) pwin=win32ui.FindWindow(None,label) print("pwin is %s" % pwin) print pwin.GetWindowText() print("click...") button2=win32ui.FindWindowEx(pwin,None,None,'下一步(&N) >') #找到按钮 button2.SendMessage(win32con.BM_CLICK, 0,-1) button2=win32ui.FindWindowEx(pwin,None,None,'下一步(&N) >') #找到按钮 button2.SendMessage(win32con.BM_CLICK, 0,-1) button2=win32ui.FindWindowEx(pwin,None,None,'下一步(&N) >') #找到按钮 button2.SendMessage(win32con.BM_CLICK, 0,-1) button2=win32ui.FindWindowEx(pwin,None,None,'完成') #找到按钮 button2.SendMessage(win32con.BM_CLICK, 0,-1) print("install done...") # 鼠标点击 #print("click...") #win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN,0,0) #time.sleep(0.1) #win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP,0,0) #time.sleep(1) #win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN,0,0) #time.sleep(0.1) #win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP,0,0) #time.sleep(1) #win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN,0,0) #time.sleep(0.1) #win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP,0,0) #time.sleep(1) #win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN,0,0) #time.sleep(0.1) #win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP,0,0) elif(sysstr == "Linux"): print ("Call Linux tasks") else: print ("Other System tasks") try: print("import psutil...") import psutil except Exception,e: print Exception,":",e install() import psutil def get_proc_by_id(pid): return psutil.Process(pid) def get_proc_by_name(pname): """ get process by name return the first process if there are more than one """ for proc in psutil.process_iter(): try: <span style="white-space:pre"> </span># return if found one if proc.name().lower() == pname.lower():<span style="white-space:pre"> </span> return proc<span style="white-space:pre"> </span> except psutil.AccessDenied: pass except psutil.NoSuchProcess: pass return None def getProcess(pname, day=0, hour=0, min=0, second=0): # Init time now = datetime.now() strnow = now.strftime('%Y-%m-%d %H:%M:%S') print "now:",strnow # First next run time period = timedelta(days=day, hours=hour, minutes=min, seconds=second) next_time = now + period strnext_time = next_time.strftime('%Y-%m-%d %H:%M:%S') print "next run time:",strnext_time while True: # Get system current time iter_now = datetime.now() iter_now_time = iter_now.strftime('%Y-%m-%d %H:%M:%S') if str(iter_now_time) == str(strnext_time): next_time = iter_now + period strnext_time = next_time.strftime('%Y-%m-%d %H:%M:%S') print "next run time:",strnext_time try: Process=get_proc_by_name(pname) except Exception,e: print Exception,":",e if Process != None : print "-------Found the process : %s" % Process.name(); print("pid is (%s)" % Process.pid); Cpu_usage = Process.cpu_percent(interval=1) print("cpu percent is (%s)" % Cpu_usage); if (100-Cpu_usage) < 0.1 : print "cpu percent larger 60,now will terminate this process !"; Process.terminate(); Process.wait(timeout=3); continue RAM_percent = Process.memory_percent() print("memory percent is (%s)" % RAM_percent); if (60-RAM_percent) < 0.1 : print "memory percent larger 60,now will terminate this process !"; Process.terminate(); Process.wait(timeout=3); continue all_files = list(Process.open_files()); print("open files size is (%d)" % len(all_files)); if (len(all_files)>300) : print "open files size larger 300,now will terminate this process !"; Process.terminate(); Process.wait(timeout=3); continue Threads_Num=Process.num_threads() print("threads number is (%s)" % Threads_Num); if (Threads_Num>200) : print "threads number larger 200,now will terminate this process !"; Process.terminate(); Process.wait(timeout=3); continue else : print "-------No found the process : %s" % pname; continue if __name__ == '__main__': print("main....") getProcess("QQ.exe",second=5)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
python,监控进程
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“python监控进程脚本”评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新动态
2024年11月26日
2024年11月26日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]