天天看点

python psutil模块系统监控详解

文章目录

  • ​​1 psutil介绍​​
  • ​​2 psutil安装​​
  • ​​3 psutil实战​​
  • ​​3.1 获取cpu信息​​
  • ​​3.2 获取内存信息​​
  • ​​3.3 获取磁盘信息​​
  • ​​3.4 获取网络信息​​
  • ​​3.5 进程信息​​
  • ​​3.6 其他信息​​

1 psutil介绍

2 psutil安装

wget https://pypi.python.org/packages/source/p/psutil/psutil-2.0.0.tar.gz
tar -xzvf psutil-2.0.0.tar.gz
cd psutil-2.0.0
python setup.py install
#or
pip install psutil      

3 psutil实战

3.1 获取cpu信息

[root@localhost psutil]# cat psutil1.py 
#!/usr/bin/python
#coding:utf-8
import psutil
#获取CPU的完整信息
print psutil.cpu_times()
#获取CPU的USER的时间比
print psutil.cpu_times().user
#CPU逻辑个数
print psutil.cpu_count()
#CPU物理个数
print psutil.cpu_count(logical=False)
#获取cpu的使用率
print psutil.cpu_percent()
#获取进程为1的cpu的使用率
print psutil.cpu_percent(1)
[root@localhost psutil]# python psutil1.py 
scputimes(user=21.13, nice=0.0, system=35.92, idle=6167.98, iowait=0.96, irq=0.0, softirq=1.15, steal=0.0, guest=0.0, guest_nice=0.0)
21.13
2
1
0.0
0.0      

3.2 获取内存信息

[root@localhost psutil]# cat psutil2.py
#!/usr/bin/python
#coding:utf-8
import psutil
mem = psutil.virtual_memory()
#获取内存完整信息
print mem
#获取总内存信息
print mem.total
#以MB为单位获取总内存信息
print(str(mem.total/1024/1024) + 'MB')
#获取已用信息
print mem.used
#获取空闲信息
print mem.free

#获取交换分区信息
print psutil.swap_memory()
[root@localhost psutil]# python psutil2.py 
svmem(total=1907802112, available=1568444416, percent=17.8, used=182579200, free=1478758400, active=142086144, inactive=158580736, buffers=2170880, cached=244293632, shared=10051584, slab=54722560)
1907802112
1819MB
182579200
1478758400
sswap(total=2147479552, used=0, free=2147479552, percent=0.0, sin=0, sout=0)      

3.3 获取磁盘信息

[root@localhost psutil]# cat psutil3.py 
#!/usr/bin/python
#coding:utf-8
import psutil

#获取系统总磁盘分区信息
print '获取系统总磁盘分区信息:' + str(psutil.disk_partitions())
#获取根分区磁盘大小
print '根分区磁盘大小:' + str(psutil.disk_usage('/'))
#获取总磁盘的I/O的读写信息
print '*'*10
print '总磁盘的I/O的读写信息:' +  str(psutil.disk_io_counters())
#获取每个磁盘的I/O的读写信息
print '每个磁盘的I/O的读写信息:' + str(psutil.disk_io_counters(perdisk=True))
[root@localhost psutil]# python psutil3.py 
获取系统总磁盘分区信息:[sdiskpart(device='/dev/mapper/centos-root', mountpoint='/', fstype='xfs', opts='rw,relatime,attr2,inode64,noquota'), sdiskpart(device='/dev/sda1', mountpoint='/boot', fstype='xfs', opts='rw,relatime,attr2,inode64,noquota'), sdiskpart(device='/dev/mapper/centos-root', mountpoint='/var/lib/docker/containers', fstype='xfs', opts='rw,relatime,attr2,inode64,noquota'), sdiskpart(device='/dev/mapper/centos-root', mountpoint='/var/lib/docker/overlay2', fstype='xfs', opts='rw,relatime,attr2,inode64,noquota')]
根分区磁盘大小:sdiskusage(total=50432839680, used=8449806336, free=41983033344, percent=16.8)
**********
总磁盘的I/O的读写信息:sdiskio(read_count=11597, write_count=3662, read_bytes=456081920, write_bytes=52591104, read_time=6938, write_time=5274, read_merged_count=0, write_merged_count=308, busy_time=6464)
每个磁盘的I/O的读写信息:{'sr0': sdiskio(read_count=0, write_count=0, read_bytes=0, write_bytes=0, read_time=0, write_time=0, read_merged_count=0, write_merged_count=0, busy_time=0), 'sda2': sdiskio(read_count=5732, write_count=1672, read_bytes=214466560, write_bytes=25236480, read_time=3401, write_time=2310, read_merged_count=0, write_merged_count=308, busy_time=3203), 'sda': sdiskio(read_count=5934, write_count=1682, read_bytes=243925504, write_bytes=27354624, read_time=3547, write_time=2321, read_merged_count=0, write_merged_count=308, busy_time=3280), 'sda1': sdiskio(read_count=170, write_count=10, read_bytes=27615744, write_bytes=2118144, read_time=134, write_time=11, read_merged_count=0, write_merged_count=0, busy_time=72), 'dm-0': sdiskio(read_count=5571, write_count=1980, read_bytes=209502208, write_bytes=25236480, read_time=3367, write_time=2953, read_merged_count=0, write_merged_count=0, busy_time=3169), 'dm-1': sdiskio(read_count=92, write_count=0, read_bytes=2654208, write_bytes=0, read_time=24, write_time=0, read_merged_count=0, write_merged_count=0, busy_time=15)}      

3.4 获取网络信息

[root@localhost psutil]# cat psutil4.py 
#!/usr/bin/python
#coding:utf-8
import psutil
#获取网络总IO信息
print psutil.net_io_counters()  
print '*' * 20
#输出网络每个接口信息
print psutil.net_io_counters(pernic=True) 
[root@localhost psutil]# python psutil4.py 
snetio(bytes_sent=1048099, bytes_recv=1294529, packets_sent=5664, packets_recv=8237, errin=0, errout=0, dropin=0, dropout=0)
********************
{'lo': snetio(bytes_sent=0, bytes_recv=0, packets_sent=0, packets_recv=0, errin=0, errout=0, dropin=0, dropout=0), 'docker0': snetio(bytes_sent=0, bytes_recv=0, packets_sent=0, packets_recv=0, errin=0, errout=0, dropin=0, dropout=0), 'eth0': snetio(bytes_sent=1048099, bytes_recv=1294529, packets_sent=5664, packets_recv=8237, errin=0, errout=0, dropin=0, dropout=0)}      

3.5 进程信息

[root@localhost psutil]# cat psutil5.py 
#!/usr/bin/python
#coding:utf-8
import psutil

#查看全部进程
print psutil.pids()

p = psutil.Process(2) 
print p.name()   #进程名
print p.exe()    #进程的bin路径
print p.cwd()    #进程的工作目录绝对路径
print p.status()   #进程状态
print p.create_time()  #进程创建时间
print p.uids()    #进程uid信息
print p.gids()    #进程的gid信息
print p.cpu_times()   #进程的cpu时间信息,包括user,system两个cpu信息
print p.cpu_affinity()  #get进程cpu亲和度,如果要设置cpu亲和度,将cpu号作为参考就好
print p.memory_percent()  #进程内存利用率
print p.memory_info()    #进程内存rss,vms信息
print p.io_counters()    #进程的IO信息,包括读写IO数字及参数
print p.connections()   #返回进程列表
print p.num_threads()  #进程开启的线程数

#听过psutil的Popen方法启动应用程序,可以跟踪程序的相关信息
from subprocess import PIPE
p = psutil.Popen(["/usr/bin/python", "-c", "print('hello')"],stdout=PIPE)
print p.name()
print p.username()
[root@localhost psutil]# python psutil5.py 
[1, 2, 4, 6, 7, 8, 9, 10, 11, 12, 13, 14, 16, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 31, 36, 37, 38, 39, 47, 48, 49, 50, 51, 53, 66, 98, 100, 277, 279, 280, 281, 307, 313, 318, 319, 322, 323, 325, 329, 330, 404, 405, 415, 416, 429, 430, 431, 432, 433, 434, 435, 436, 437, 438, 439, 440, 511, 532, 534, 585, 590, 593, 594, 595, 602, 603, 611, 616, 617, 619, 621, 687, 691, 692, 713, 714, 715, 716, 718, 722, 727, 730, 733, 737, 750, 752, 753, 762, 767, 780, 1116, 1118, 1120, 1121, 1136, 1137, 1145, 1146, 1174, 1362, 1363, 1364, 1623, 1625, 6488, 7050, 7687, 7745, 8205, 8240]
kthreadd

/
sleeping
1585555747.03
puids(real=0, effective=0, saved=0)
pgids(real=0, effective=0, saved=0)
pcputimes(user=0.0, system=0.0, children_user=0.0, children_system=0.0, iowait=0.0)
[0, 1]
0.0
pmem(rss=0, vms=0, shared=0, text=0, lib=0, data=0, dirty=0)
pio(read_count=0, write_count=0, read_bytes=0, write_bytes=0, read_chars=0, write_chars=0)
[]
1
python
root
close failed in file object destructor:
sys.excepthook is missing
lost sys.stderr      

3.6 其他信息

[root@localhost psutil]# cat psutil6.py 
#!/usr/bin/python
#coding:utf-8
import psutil
import datetime
#获取当前系统用户登录信息
print psutil.users()
#获取开机时间
print psutil.boot_time() #以linux时间格式返回
print datetime.datetime.fromtimestamp(psutil.boot_time ()).strftime("%Y-%m-%d %H: %M: %S") #转换成自然时间格式
[root@localhost psutil]# python psutil6.py
[suser(name='root', terminal='pts/0', host='192.168.211.1', started=1585555840.0, pid=1625)]
1585555747.0
2020-03-30 16: 09: 07