Python测试进阶——(5)Python程序监控指定进程的CPU和内存利用率
用Python写了个简单的监控进程的脚本monitor190620.py,记录进程的CPU利用率和内存利用率到文件pid.csv中,分析进程运行数据用图表展示。
脚本的工作原理是这样的:脚本读取配置文件config.ini,读取预先配置好的进程的PID,之所以要用配置文件,是为了方便给需要的朋友,你只需要修改PID就可以了,源代码就不需要修改了。具体的看代码中的注释吧。下面的是配置文件 config.ini
[MonitorProcessID] ProcessID: 7544
上面可以根据你的需求配置不同的进程ID,我是需要监控 JMeter这个程序,通过 jps -l 查看该进程的PID,填写配置文件内容。
下面来看看monitor190620.py的代码(该代码在CentOS下运行时需要改正一行代码:from ConfigParser import ConfigParser):
# -*- encoding: utf-8 -*-
import psutil
import csv
import time
from configparser import ConfigParser
CONFIGFILE = 'config.ini'
config = ConfigParser()
config.read(CONFIGFILE)
ProcessID = config.get('MonitorProcessID', 'ProcessID')
# 读取配置文件中的进程ID,这个参数可以在配置文件中修改
proc = psutil.Process(int(ProcessID))
#print(ProcessID,"% .2f% %"%(proc.memory_percent()),"% .2f% %"%(proc.cpu_percent()),proc.name(),proc.exe())
f = open('pid.csv', 'w')
f.truncate()
f_csv = csv.writer(f)
flag = 1
while flag < 10:
row = []
row = [ProcessID,'%.2f'%(proc.memory_percent()),'%.2f'%(proc.cpu_percent()),time.strftime("%H:%M:%S", time.localtime()),proc.name(),proc.exe()]
f_csv.writerow(row)
flag += 1
time.sleep(4)
f.close()
执行后,生成的 pid.csv 的文件内容为:
7544,3.12,0.00,15:39:12,java.exe,C:\Program Files (x86)\Common Files\Oracle\Java\javapath_target_119167744\java.exe 7544,3.12,0.00,15:39:16,java.exe,C:\Program Files (x86)\Common Files\Oracle\Java\javapath_target_119167744\java.exe 7544,3.12,0.00,15:39:20,java.exe,C:\Program Files (x86)\Common Files\Oracle\Java\javapath_target_119167744\java.exe 7544,3.12,0.00,15:39:24,java.exe,C:\Program Files (x86)\Common Files\Oracle\Java\javapath_target_119167744\java.exe 7544,3.12,0.00,15:39:28,java.exe,C:\Program Files (x86)\Common Files\Oracle\Java\javapath_target_119167744\java.exe 7544,3.12,0.00,15:39:32,java.exe,C:\Program Files (x86)\Common Files\Oracle\Java\javapath_target_119167744\java.exe 7544,3.12,0.00,15:39:36,java.exe,C:\Program Files (x86)\Common Files\Oracle\Java\javapath_target_119167744\java.exe 7544,3.12,0.00,15:39:40,java.exe,C:\Program Files (x86)\Common Files\Oracle\Java\javapath_target_119167744\java.exe 7544,3.12,0.00,15:39:44,java.exe,C:\Program Files (x86)\Common Files\Oracle\Java\javapath_target_119167744\java.exe
编写 show190620.py ,读取 pid.csv 的文件内容,做统计分析,并将分析结果可视化为图表:
import csv
import pandas as pd
import matplotlib.pyplot as plt
time = []
cpu = []
mem = []
with open('pid.csv')as f:
f_csv = csv.reader(f)
for row in f_csv:
if len(row): #判断是不是空行,csv中隔一行记录运行的信息
time.append(row[3])
cpu.append(float(row[2]))
mem.append(float(row[1]))
else:
continue
print(time)
print(cpu)
print(mem)
s_cpu = pd.Series(cpu)
s_mem = pd.Series(mem)
cpu_mean = s_cpu.mean()
mem_mean = s_mem.mean()
print('cpu利用率平均值是:%f' % cpu_mean)
print('内存利用率平均值是:%f' % mem_mean)
plt.plot(time,cpu, c='r')
plt.plot(time,mem, c='b')
plt.show()
返回信息:
['15:39:12', '15:39:16', '15:39:20', '15:39:24', '15:39:28', '15:39:32', '15:39:36', '15:39:40', '15:39:44'] [0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0] [3.12, 3.12, 3.12, 3.12, 3.12, 3.12, 3.12, 3.12, 3.12] cpu利用率平均值是:0.000000 内存利用率平均值是:3.120000
并显示图表:

参考:
https://www.cnblogs.com/yueminghai/p/6632871.html
https://www.cnblogs.com/xiaobeibei26/p/6481707.html
https://www.cnblogs.com/ratels/p/11023109.html
https://www.cnblogs.com/sen-c7/p/9473224.html
https://blog.csdn.net/cz505632696/article/details/80025816
https://blog.csdn.net/katyusha1/article/details/81606175
https://www.runoob.com/python/python-lists.html
https://www.cnblogs.com/AiyaFocus/p/AiyaFocus.html
https://www.cnblogs.com/haiyan123/p/9104143.html
https://www.cnblogs.com/deepblue775737449/p/8507078.html
https://www.cnblogs.com/ratels/p/11037661.html
Python测试进阶——(5)Python程序监控指定进程的CPU和内存利用率的更多相关文章
- 监控单个进程占用cpu与内存的使用情况
#!/bin/bashinterval=1if [ "$1" != "" ]then interval=$1fiecho "检查时间间隔(单位秒):& ...
- Python测试进阶——(4)Python程序监控、存储、分析并可视化CPU和内存利用率
monitor190617.py 监控cpu和内存利用率信息,组织成json格式,并写入到 record.txt 文件中: import psutil import time import json ...
- 监控系统负载与CPU、内存、硬盘、登录用户数,超出警戒值则发邮件告警。
zzx@zzx:~$ cat warning.sh #!/bin/bash #监控系统负载与CPU.内存.硬盘.登录用户数,超出警戒值则发邮件告警. 前提安装mail服务nh=`uname -r ...
- 转:ZABBIX监控H3C设备的CPU和内存使用率
由于最近监控的H3C路由器经常出现死机现象,SNMP获取不到数据,后面检查发现是CPU使用率过高,直接导致无法处理SNMP请求,所以需求来了,怎样通过SNMP监控H3C路由器的CPU和内存使用率? ...
- Python测试进阶——(3)编写Python程序监控计算机的服务是否正常运行
用python写了个简单的监控进程的脚本,当发现进程消失的时候,立即调用服务,开启服务. 脚本的工作原理是这样的:脚本读取配置文件,读取预先配置好的调用系统服务的路径和所要监控的服务在进程管理器中的进 ...
- Python高级进阶(一)Python框架之Django入门
传说中的Django Django由来 Django是一个开放源代码的Web应用框架,由Python写成.采用了MVC的框架模式,即模型M,视图V和控制器C.它最初是被开发来用于管理劳伦斯出版集团旗下 ...
- Python编程进阶,Python如何实现多进程?
进程part1 一.进程介绍 1.获取子父进程 2.进程的基本使用 2.创建带有参数的进程 3.进程之间的数据彼此隔离 4.多个进程之间的异步并发 二.join 1.基本语法 2.使用自定义类的方法创 ...
- shell脚本监控系统负载、CPU和内存使用情况
hostname >>/home/vmuser/xunjian/xj.logdf -lh >>/home/vmuser/xunjian/xj.logtop -b -n 1 | ...
- Python测试进阶——(1)安装Python测试相关模块
安装python 安装pip yum -y install epel-release yum -y install python-pip 安装psutil 参考:https://www.cnblogs ...
随机推荐
- centos 默认php 版本太低移到高版本的办法
// centos 默认有php 版本太低转移到高版本的解决办法 php -v 版本低 ln -s /usr/local/php/bin/php /usr/bin/php
- ElementUI el-message 提示信息的用法
引入message Element 注册了一个$message方法用于调用,Message 可以接收一个字符串或一个 VNode 作为参数,它会被显示为正文内容. Element 为 Vue.prot ...
- Java中短路
当使用逻辑运算符时,我们会遇到一种“短路”的现象.即一旦能够准确无误的确定整个表达式的值,就不再计算表达式余下的部分了.因此整个表达式靠后的部分有可能不被运算 /**短路 * @param args ...
- 孤荷凌寒自学python第103天认识区块链017
[主要内容] 今天继续分析从github上获取的开源代码怎么实现简单区块链的入门知识,共用时间25分钟. (此外整理作笔记花费了约34分钟) 详细学习过程见文末学习过程屏幕录像. 今天所作的工作是进一 ...
- Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)E(多重集维护)
#define HAVE_STRUCT_TIMESPEC#include<bits/stdc++.h>using namespace std;long long ans[1000007]; ...
- thymeleaf 学习笔记(转)
原文:http://blog.csdn.net/pdw2009/article/details/44410659 thymeleaf,我个人认为是个比较好的模板,性能也比一般的,比如freemaker ...
- jsp 页面使用标签遍历
<tbody> <c:forEach items="${page.list}" var="exhiMain"> <c:set va ...
- error C4430: missing type specifier - int assumed. Note: C++ does not support default-int 解决方法
在VS2012中生成时出错:error C4430: missing type specifier - int assumed. Note: C++ does not support default- ...
- 5.使用Redis+Flask维护动态Cookies池
1.为什么要用Cookies池? 网站需要登录才可爬取,例如新浪微博 爬取过程中如果频率过高会导致封号 需要维护多个账号的Cookies池实现大规模爬取 2.Cookies池的要求 自动登录更新 定时 ...
- INI文件,WritePrivateProfileString()和GetPrivateProfileString()函数----转载
INI文件就是扩展名为“ini”的文件.在Windows系统中,INI文件是很多,最重要的就是“System.ini”.“System32.ini”和“Win.ini”.该文件主要存放用户所做的选择以 ...