About
psutil(python系统和流程实用程序)是一个跨平台库,用于在Python中检索有关正在运行的 进程和系统利用率(CPU,内存,磁盘,网络,传感器)的信息。它主要用于系统监视,分析,限制进程资源和运行进程的管理。它实现了UNIX命令行工具提供的许多功能,例如:ps,top,lsof,netstat,ifconfig,who,df,kill,free,nice,ionice,iostat,iotop,uptime,pidof,tty,taskset,pmap。psutil目前支持以下平台:
- Linux的
- Windows
- macOS
- FreeBSD,OpenBSD,NetBSD
- Sun Solaris
- AIX
支持Python版本是2.6,2.7和3.4+。
Install
psutil安装也相当方便:
- windows平台直接使用pip安装即可。
pip install psutil # psutil for windows
- Linux平台可以选择tar包方式安装。
wget https://pypi.python.org/packages/source/p/psutil/psutil-3.2.1.tar.gz --no-check-certificate
tar zxvf psutil-3.2.1.tar.gz
cd psutil-3.2.1
python setup.py install
CPU
- 获取CPU逻辑核数。
logical
参数默认为True
,指获取逻辑核数。
python
print(psutil.cpu_count(logical=True)) # 4
- 获取CPU物理核数。
python
print(psutil.cpu_count(logical=False))
- 以百分比的形式返回表示当前CPU的利用率的浮点数。
interval
参数必须设置为大于0,因为它测试的是时间间隔内的利用率。percpu
参数为True
则所有CPU利用率的浮点列表,列表的顺序在调用之间是一致的。
python
print(psutil.cpu_percent(interval=1, percpu=True)) # [17.2, 23.4, 15.6, 15.6]
- 在特定模式下,返回CPU所花费的时间百分比。
python
print(psutil.cpu_times_percent(interval=1, percpu=True)) # [scputimes(user=3.1, system=3.1, idle=92.3, interrupt=0.0, dpc=1.5), scputimes(user=0.0, system=6.2, idle=92.3, interrupt=1.5, dpc=0.0), scputimes(user=7.8, system=0.0, idle=92.2, interrupt=0.0, dpc=0.0), scputimes(user=0.0, system=1.6, idle=98.4, interrupt=0.0, dpc=0.0)]
- 在特定模式下,返回CPU所花费的时间(单位为秒)。
python
print(psutil.cpu_times()) # scputimes(user=24555.5, system=24045.421875, idle=470324.85937499994, interrupt=1376.078125, dpc=482.375)
- 将各种CPU统计信息作为命名元组返回。
python
print(psutil.cpu_stats()) # scpustats(ctx_switches=3004844087, interrupts=1850612695, soft_interrupts=0, syscalls=1767814215)
- 将CPU频率作为名称包返回,包括 以Mhz表示的当前,最小和最大频率。在Linux 当前频率上报告实时值,在所有其他平台上它代表名义上的“固定”值。如果percpu是True并且系统支持每CPU频率检索(仅限Linux),则为每个CPU返回频率列表,否则返回包含单个元素的列表。如果无法确定最小值和最大值,则将它们设置为0。
python
print(psutil.cpu_freq(percpu=True)) # [scpufreq(current=2000.0, min=0.0, max=2501.0)]
Memory
获取内存使用情况。相关参数,单位(字节):
- total,总大小。
- available,可用内存。
- used,已使用。
- free,空闲。
- percent,使用率。
需要注意的是,已使用和可用不等于总和。
python
print(psutil.virtual_memory()) # svmem(total=12797194240, available=6384398336, percent=50.1, used=6412795904, free=6384398336)
- 获取交换分区内存统计信息。相关参数,单位(字节):
- total,总大小。
- used,已使用地swap内存。
- free,空闲。
- sin,系统累计从磁盘交换的字节数。
- sout,系统累计从磁盘换出的字节数。
python
print(psutil.swap_memory()) # sswap(total=19490631680, used=7854170112, free=11636461568, percent=40.3, sin=0, sout=0)
Disk
- 返回所有磁盘分区信息。包括设备,挂载点和文件系统类型。
python
print(psutil.disk_partitions(all=False))
'''
[
sdiskpart(device='C:\\', mountpoint='C:\\', fstype='NTFS', opts='rw,fixed'),
sdiskpart(device='D:\\', mountpoint='D:\\', fstype='', opts='cdrom'),
sdiskpart(device='E:\\', mountpoint='E:\\', fstype='NTFS', opts='rw,fixed'),
sdiskpart(device='F:\\', mountpoint='F:\\', fstype='NTFS', opts='rw,fixed'),
sdiskpart(device='G:\\', mountpoint='G:\\', fstype='NTFS', opts='rw,fixed'),
sdiskpart(device='M:\\', mountpoint='M:\\', fstype='NTFS', opts='rw,fixed')
]
'''
- 返回指定磁盘的信息。相关参数,单位(字节):
- total,总大小。
- used,使用。
- free,空闲。
- percent,使用率。
python
print(psutil.disk_usage('C:\\')) # sdiskusage(total=128034672640, used=98790318080, free=29244354560, percent=77.2)
for d in psutil.disk_partitions():
if d[3] != 'cdrom': # 排除windows中的cd驱动器
item = psutil.disk_usage(d[0])
print('磁盘 {0} 总大小 {1[0]} 使用 {1[1]} 空闲 {1[2]} 使用率 {1[3]}'.format(d[0], item))
'''
磁盘 C:\ 总大小 128034672640 使用 98801184768 空闲 29233487872 使用率 77.2
磁盘 E:\ 总大小 2000396320768 使用 1566692167680 空闲 433704153088 使用率 78.3
磁盘 F:\ 总大小 368532213760 使用 107016785920 空闲 261515427840 使用率 29.0
磁盘 G:\ 总大小 314572795904 使用 86216327168 空闲 228356468736 使用率 27.4
磁盘 M:\ 总大小 317093572608 使用 133029965824 空闲 184063606784 使用率 42.0
'''
- 获取磁盘
I/O
统计信息。相关参数:- read_count,读取次数。
- write_count,写入次数。
- read_bytes,读取的字节数。
- write_bytes,写入的字节数。
python
print(psutil.disk_io_counters()) # sdiskio(read_count=1066650, write_count=1677203, read_bytes=61252281856, write_bytes=77213490688, read_time=21399, write_time=125572)
Network
- 获取网络
I/O
信息。相关参数:- bytes_sent:发送的字节数
- bytes_recv:接收的字节数
- packets_sent:发送的包数
- packets_recv:接收的数据包数
- errin:接收时的错误总数
- errout:发送时的错误总数
- dropin:丢弃的传入数据包总数
- dropout:丢弃的传出数据包总数(macOS和BSD总是0)
python
print(psutil.net_io_counters()) # snetio(bytes_sent=195227541, bytes_recv=1240643732, packets_sent=887249, packets_recv=1320281, errin=0, errout=0, dropin=0, dropout=0)
- 获取系统的套接字信息。每个命名元组都提供7个属性:
- fd:套接字文件描述符。如果连接引用当前进程,则可以将其传递给socket.fromfd 以获取可用的套接字对象。在Windows和SunOS上,它始终设置为
-1
。 - family:地址族,AF_INET,AF_INET6或AF_UNIX。
- type:地址类型,SOCK_STREAM或SOCK_DGRAM。
- laddr:作为命名元组的本地地址或 AF_UNIX套接字的情况。对于UNIX套接字,请参阅下面的注释。
(ip, port)``path
- raddr:作为命名元组的远程地址或UNIX套接字的绝对地址。当远程端点未连接时,您将获得一个空元组(AF_INET *)或(AF_UNIX)。对于UNIX套接字,请参阅下面的注释。
(ip, port)``path``""
- status:表示TCP连接的状态。返回值是psutil.CONN_ *常量之一(字符串)。对于UDP和UNIX套接字,这总是如此
psutil.CONN_NONE
。 - pid:打开套接字的进程的PID,如果可以检索,否则
None
。在某些平台(例如Linux)上,此字段的可用性会根据进程权限(需要root)而更改。
- fd:套接字文件描述符。如果连接引用当前进程,则可以将其传递给socket.fromfd 以获取可用的套接字对象。在Windows和SunOS上,它始终设置为
python
print(psutil.net_connections())
'''
[
sconn(fd=-1, family=<AddressFamily.AF_INET: 2>, type=2, laddr=addr(ip='127.0.0.1', port=58646), raddr=(), status='NONE', pid=4012),
sconn(fd=-1, family=<AddressFamily.AF_INET: 2>, type=1, laddr=addr(ip='0.0.0.0', port=135), raddr=(), status='LISTEN', pid=880),
......
]
'''
- 获取网卡地址相关信息。相关参数:
- family:地址族,AF_INET或AF_INET6, 或者
psutil.AF_LINK
指MAC地址。 - address:主NIC地址(始终设置)。
- netmask:网络掩码地址(可能是
None
)。 - 广播:广播地址(可能是
None
)。 - ptp:代表“点对点”; 它是点对点接口(通常是VPN)上的目标地址。广播和ptp是互斥的。可能是
None
。
- family:地址族,AF_INET或AF_INET6, 或者
python
print(psutil.net_if_addrs())
'''
{
'以太网': [snicaddr(family=<AddressFamily.AF_LINK: -1>, address='28-D2-44-6A-20-79', netmask=None, broadcast=None, ptp=None), snicaddr(family=<AddressFamily.AF_INET: 2>, address='192.168.0.98', netmask='255.255.255.0', broadcast=None, ptp=None)],
'本地连接* 2': [snicaddr(family=<AddressFamily.AF_LINK: -1>, address='1A-E3-47-B5-C4-1C', netmask=None, broadcast=None, ptp=None), snicaddr(family=<AddressFamily.AF_INET: 2>, address='169.254.45.250', netmask='255.255.0.0', broadcast=None, ptp=None), snicaddr(family=<AddressFamily.AF_INET6: 23>, address='fe80::610d:c08e:fbaf:2dfa', netmask=None, broadcast=None, ptp=None)],
......
}
'''
- 获取网卡的信息,相关参数:
- isup:指示NIC是否已启动并运行的bool。
- duplex:双工通信类型; 它可以是
NIC_DUPLEX_FULL
,NIC_DUPLEX_HALF
或NIC_DUPLEX_UNKNOWN
。 - speed:以兆位(MB)表示的NIC速度,如果无法确定(例如'localhost'),它将被设置为
0
。 - mtu:NIC的最大传输单位,以字节为单位。
python
print(psutil.net_if_stats())
'''
{
'以太网': snicstats(isup=True, duplex=<NicDuplex.NIC_DUPLEX_FULL: 2>, speed=1000, mtu=1500),
'蓝牙网络连接': snicstats(isup=False, duplex=<NicDuplex.NIC_DUPLEX_FULL: 2>, speed=3, mtu=1500), 'VMware Network Adapter VMnet1': snicstats(isup=True, duplex=<NicDuplex.NIC_DUPLEX_FULL: 2>, speed=100, mtu=1500), 'VMware Network Adapter VMnet8': snicstats(isup=True, duplex=<NicDuplex.NIC_DUPLEX_FULL: 2>, speed=100, mtu=1500),
'以太网 2': snicstats(isup=False, duplex=<NicDuplex.NIC_DUPLEX_FULL: 2>, speed=100, mtu=1500), 'Loopback Pseudo-Interface 1': snicstats(isup=True, duplex=<NicDuplex.NIC_DUPLEX_FULL: 2>, speed=1073, mtu=1500), 'WLAN': snicstats(isup=False, duplex=<NicDuplex.NIC_DUPLEX_FULL: 2>, speed=108, mtu=1500),
'本地连接* 2': snicstats(isup=False, duplex=<NicDuplex.NIC_DUPLEX_FULL: 2>, speed=0, mtu=1500),
'本地连接* 4': snicstats(isup=False, duplex=<NicDuplex.NIC_DUPLEX_FULL: 2>, speed=0, mtu=1500),
'本地连接* 3': snicstats(isup=False, duplex=<NicDuplex.NIC_DUPLEX_FULL: 2>, speed=0, mtu=1472)
}
'''
其他信息
- 获取系统进程pid
python
import os
import psutil
psutil.pids() # 以列表的形式返回系统所有进程pid号
print([{psutil.Process(pid).name(): pid} for pid in psutil.pids()]) # 返回进程名称和pid的列表
os.system('taskkill /F /IM wmplayer.exe') # 借助os模块强制杀死指定进程
- 获取系统开机时间
python
import time
import psutil
print(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(psutil.boot_time()))) # 2019-05-28 08:16:31
- 获取当前用户登录信息
python
print(psutil.users()) # [suser(name='Anthony', terminal=None, host='0.0.0.0', started=1559002601.0, pid=None)]
- linux系统返回硬件温度。
python
print(psutil.sensors_temperatures()) # windows下抛出AttributeError: module 'psutil' has no attribute 'sensors_temperatures'
- linux获取硬件风扇转速。
python
print(psutil.sensors_fans())
- 返回电池信息。相关参数:
- 百分比:电池剩余百分比。
- secsleft:电池电量耗尽前剩余的秒数的粗略近似值。如果连接了交流电源线,则设置为
psutil.POWER_TIME_UNLIMITED
。如果无法确定它被设置为psutil.POWER_TIME_UNKNOWN
。 - power_plugged:
True
如果连接了交流电源线,False
如果没有,或者None
无法确定。
python
print(psutil.sensors_battery()) # sbattery(percent=100, secsleft=<BatteryTime.POWER_TIME_UNLIMITED: -2>, power_plugged=True)
欢迎斧正,that's all see also:
python模块之psutil详解 | psutil documentation — psutil 5.6.3 documentation