psutil介绍


用Python来编写脚本简化日常的运维工作是Python的一个重要用途。在Linux下,有许多系统命令可以让我们时刻监控系统运行的状态,如pstopfree等等。要获取这些系统信息,Python可以通过subprocess模块调用并获取结果。但这样做显得很麻烦,尤其是要写很多解析代码。

在Python中获取系统信息的另一个好办法是使用psutil这个第三方模块。顾名思义,psutil = process and system utilities,它不仅可以通过一两行代码实现系统监控,还可以跨平台使用,支持Linux/UNIX/OSX/Windows等,是系统管理员和运维小伙伴不可或缺的必备模块。

安装psutil

如果安装了Anaconda,psutil就已经可用了。否则,需要在命令行下通过pip安装:

  1. $ pip install psutil

如果遇到Permission denied安装失败,请加上sudo重试。

获取CPU信息

我们先来获取CPU的信息:

  1. >>> import psutil
  2. >>> psutil.cpu_count() # CPU逻辑数量
  3. 4
  4. >>> psutil.cpu_count(logical=False) # CPU物理核心
  5. 2
  6. # 2说明是双核超线程, 4则是4核非超线程

统计CPU的用户/系统/空闲时间:

  1. >>> psutil.cpu_times()
  2. scputimes(user=10963.31, nice=0.0, system=5138.67, idle=356102.45)

再实现类似top命令的CPU使用率,每秒刷新一次,累计10次:

  1. >>> for x in range(10):
  2. ... psutil.cpu_percent(interval=1, percpu=True)
  3. ...
  4. [14.0, 4.0, 4.0, 4.0]
  5. [12.0, 3.0, 4.0, 3.0]
  6. [8.0, 4.0, 3.0, 4.0]
  7. [12.0, 3.0, 3.0, 3.0]
  8. [18.8, 5.1, 5.9, 5.0]
  9. [10.9, 5.0, 4.0, 3.0]
  10. [12.0, 5.0, 4.0, 5.0]
  11. [15.0, 5.0, 4.0, 4.0]
  12. [19.0, 5.0, 5.0, 4.0]
  13. [9.0, 3.0, 2.0, 3.0]

获取内存信息

使用psutil获取物理内存和交换内存信息,分别使用:

  1. >>> psutil.virtual_memory()
  2. svmem(total=8589934592, available=2866520064, percent=66.6, used=7201386496, free=216178688, active=3342192640, inactive=2650341376, wired=1208852480)
  3. >>> psutil.swap_memory()
  4. sswap(total=1073741824, used=150732800, free=923009024, percent=14.0, sin=10705981440, sout=40353792)

返回的是字节为单位的整数,可以看到,总内存大小是8589934592 = 8 GB,已用7201386496 = 6.7 GB,使用了66.6%。

而交换区大小是1073741824 = 1 GB。

获取磁盘信息

可以通过psutil获取磁盘分区、磁盘使用率和磁盘IO信息:

  1. >>> psutil.disk_partitions() # 磁盘分区信息
  2. [sdiskpart(device='/dev/disk1', mountpoint='/', fstype='hfs', opts='rw,local,rootfs,dovolfs,journaled,multilabel')]
  3. >>> psutil.disk_usage('/') # 磁盘使用情况
  4. sdiskusage(total=998982549504, used=390880133120, free=607840272384, percent=39.1)
  5. >>> psutil.disk_io_counters() # 磁盘IO
  6. sdiskio(read_count=988513, write_count=274457, read_bytes=14856830464, write_bytes=17509420032, read_time=2228966, write_time=1618405)

可以看到,磁盘'/'的总容量是998982549504 = 930 GB,使用了39.1%。文件格式是HFS,opts中包含rw表示可读写,journaled表示支持日志。

获取网络信息

psutil可以获取网络接口和网络连接信息:

  1. >>> psutil.net_io_counters() # 获取网络读写字节/包的个数
  2. snetio(bytes_sent=3885744870, bytes_recv=10357676702, packets_sent=10613069, packets_recv=10423357, errin=0, errout=0, dropin=0, dropout=0)
  3. >>> psutil.net_if_addrs() # 获取网络接口信息
  4. {
  5. 'lo0': [snic(family=<AddressFamily.AF_INET: 2>, address='127.0.0.1', netmask='255.0.0.0'), ...],
  6. 'en1': [snic(family=<AddressFamily.AF_INET: 2>, address='10.0.1.80', netmask='255.255.255.0'), ...],
  7. 'en0': [...],
  8. 'en2': [...],
  9. 'bridge0': [...]
  10. }
  11. >>> psutil.net_if_stats() # 获取网络接口状态
  12. {
  13. 'lo0': snicstats(isup=True, duplex=<NicDuplex.NIC_DUPLEX_UNKNOWN: 0>, speed=0, mtu=16384),
  14. 'en0': snicstats(isup=True, duplex=<NicDuplex.NIC_DUPLEX_UNKNOWN: 0>, speed=0, mtu=1500),
  15. 'en1': snicstats(...),
  16. 'en2': snicstats(...),
  17. 'bridge0': snicstats(...)
  18. }

要获取当前网络连接信息,使用net_connections()

  1. >>> psutil.net_connections()
  2. Traceback (most recent call last):
  3. ...
  4. PermissionError: [Errno 1] Operation not permitted
  5. During handling of the above exception, another exception occurred:
  6. Traceback (most recent call last):
  7. ...
  8. psutil.AccessDenied: psutil.AccessDenied (pid=3847)

你可能会得到一个AccessDenied错误,原因是psutil获取信息也是要走系统接口,而获取网络连接信息需要root权限,这种情况下,可以退出Python交互环境,用sudo重新启动:

  1. $ sudo python3
  2. Password: ******
  3. Python 3.6.3 ... on darwin
  4. Type "help", ... for more information.
  5. >>> import psutil
  6. >>> psutil.net_connections()
  7. [
  8. sconn(fd=83, family=<AddressFamily.AF_INET6: 30>, type=1, laddr=addr(ip='::127.0.0.1', port=62911), raddr=addr(ip='::127.0.0.1', port=3306), status='ESTABLISHED', pid=3725),
  9. sconn(fd=84, family=<AddressFamily.AF_INET6: 30>, type=1, laddr=addr(ip='::127.0.0.1', port=62905), raddr=addr(ip='::127.0.0.1', port=3306), status='ESTABLISHED', pid=3725),
  10. sconn(fd=93, family=<AddressFamily.AF_INET6: 30>, type=1, laddr=addr(ip='::', port=8080), raddr=(), status='LISTEN', pid=3725),
  11. sconn(fd=103, family=<AddressFamily.AF_INET6: 30>, type=1, laddr=addr(ip='::127.0.0.1', port=62918), raddr=addr(ip='::127.0.0.1', port=3306), status='ESTABLISHED', pid=3725),
  12. sconn(fd=105, family=<AddressFamily.AF_INET6: 30>, type=1, ..., pid=3725),
  13. sconn(fd=106, family=<AddressFamily.AF_INET6: 30>, type=1, ..., pid=3725),
  14. sconn(fd=107, family=<AddressFamily.AF_INET6: 30>, type=1, ..., pid=3725),
  15. ...
  16. sconn(fd=27, family=<AddressFamily.AF_INET: 2>, type=2, ..., pid=1)
  17. ]

获取进程信息

通过psutil可以获取到所有进程的详细信息:

  1. >>> psutil.pids() # 所有进程ID
  2. [3865, 3864, 3863, 3856, 3855, 3853, 3776, ..., 45, 44, 1, 0]
  3. >>> p = psutil.Process(3776) # 获取指定进程ID=3776,其实就是当前Python交互环境
  4. >>> p.name() # 进程名称
  5. 'python3.6'
  6. >>> p.exe() # 进程exe路径
  7. '/Users/michael/anaconda3/bin/python3.6'
  8. >>> p.cwd() # 进程工作目录
  9. '/Users/michael'
  10. >>> p.cmdline() # 进程启动的命令行
  11. ['python3']
  12. >>> p.ppid() # 父进程ID
  13. 3765
  14. >>> p.parent() # 父进程
  15. <psutil.Process(pid=3765, name='bash') at 4503144040>
  16. >>> p.children() # 子进程列表
  17. []
  18. >>> p.status() # 进程状态
  19. 'running'
  20. >>> p.username() # 进程用户名
  21. 'michael'
  22. >>> p.create_time() # 进程创建时间
  23. 1511052731.120333
  24. >>> p.terminal() # 进程终端
  25. '/dev/ttys002'
  26. >>> p.cpu_times() # 进程使用的CPU时间
  27. pcputimes(user=0.081150144, system=0.053269812, children_user=0.0, children_system=0.0)
  28. >>> p.memory_info() # 进程使用的内存
  29. pmem(rss=8310784, vms=2481725440, pfaults=3207, pageins=18)
  30. >>> p.open_files() # 进程打开的文件
  31. []
  32. >>> p.connections() # 进程相关网络连接
  33. []
  34. >>> p.num_threads() # 进程的线程数量
  35. 1
  36. >>> p.threads() # 所有线程信息
  37. [pthread(id=1, user_time=0.090318, system_time=0.062736)]
  38. >>> p.environ() # 进程环境变量
  39. {'SHELL': '/bin/bash', 'PATH': '/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:...', 'PWD': '/Users/michael', 'LANG': 'zh_CN.UTF-8', ...}
  40. >>> p.terminate() # 结束进程
  41. Terminated: 15 <-- 自己把自己结束了

和获取网络连接类似,获取一个root用户的进程需要root权限,启动Python交互环境或者.py文件时,需要sudo权限。

psutil还提供了一个test()函数,可以模拟出ps命令的效果:

  1. $ sudo python3
  2. Password: ******
  3. Python 3.6.3 ... on darwin
  4. Type "help", ... for more information.
  5. >>> import psutil
  6. >>> psutil.test()
  7. USER PID %MEM VSZ RSS TTY START TIME COMMAND
  8. root 0 24.0 74270628 2016380 ? Nov18 40:51 kernel_task
  9. root 1 0.1 2494140 9484 ? Nov18 01:39 launchd
  10. root 44 0.4 2519872 36404 ? Nov18 02:02 UserEventAgent
  11. root 45 ? 2474032 1516 ? Nov18 00:14 syslogd
  12. root 47 0.1 2504768 8912 ? Nov18 00:03 kextd
  13. root 48 0.1 2505544 4720 ? Nov18 00:19 fseventsd
  14. _appleeven 52 0.1 2499748 5024 ? Nov18 00:00 appleeventsd
  15. root 53 0.1 2500592 6132 ? Nov18 00:02 configd

psutil运维必会模块的更多相关文章

  1. 网络运维必回的模拟器-GNS软件下载和安装

    网络运维必回的模拟器-GNS软件下载和安装 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.GNS简介 1>.什么是GNS GNS3是一款具有图形化界面可以运行在多平台( ...

  2. (转)linux运维必会MySQL企业面试题

    linux运维必会MySQL企业面试题  老男孩教育运维班全体学员MySQL必会企业面试题最实战.最细致.最落地的运维实训基地,老男孩教育连续多年国内平均就业工资最高! 数据库的重要性是所有技术里最核 ...

  3. python运维开发常用模块(一)psutil

    1.模块简介 psutil是一个跨平台库(http://code.google.com/p/psutil/),能够轻 松实现获取系统运行的进程和系统利用率(包括CPU.内存.磁盘.网 络等)信息.它主 ...

  4. python运维开发常用模块(四)文件对比模块difflib

    1.difflib介绍 difflib作为 Python的标准库模块,无需安装,作用是对比文本之间的差异,且支持 输出可读性比较强的HTML文档,与Linux下的diff命令相似.我们可以 使用dif ...

  5. SNMP概述–运维必知的协议基础

    一.什么是SNMP?   SNMP是  “Simple Network Management Protocol” 的缩写,中文意思是简单网络管理协议,它是由互联网工作小组在RFC1157中定义的应用层 ...

  6. mysql运维必会的一些知识点整理

    (1)基础笔试命令考察 1.开启MySQL服务 /etc/init.d/mysqld start service mysqld start systemctl start mysqld 2.检测端口是 ...

  7. Linux运维必会的MySQL企业面试题大全

    (1)基础笔试命令考察 1.开启MySQL服务 /etc/init.d/mysqld start service mysqld start systemctl start mysqld 2.检测端口是 ...

  8. (转)Awk使用案例总结(运维必会)

    以下知识点可能有不对之处,请参考最新Awk学习文章:http://lizhenliang.blog.51cto.com/7876557/1892112 原文:http://blog.51cto.com ...

  9. mysql运维必会的一些知识点整理(转自民工哥)

    (1)基础笔试命令考察 1.开启MySQL服务 /etc/init.d/mysqld start service mysqld start systemctl start mysqld 2.检测端口是 ...

随机推荐

  1. 通过nodejs实现文件的上传

    通过nodejs实现文件的上传 主要内容 本文将用来讲述如何通过nodejs进行文件上传,将会涉及到以下知识点: 通过express模块进行服务器的搭建 通过multer模块将上传的文件保存到指定目录 ...

  2. js 行走的小女孩 面向对象

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. 【转】sublime text 2中Emmet插件8个常用的技巧

    因为开始做web项目,所以最近在用sublime编辑器,知道了一个传说中的emmet,原名是zen coding.html神插件可以说是.文章部分内容转自http://www.cnblogs.com/ ...

  4. php导出为excel文件避免内存溢出

    轻松解决PHPExcel导出10W行超时和内存溢出问题   使用了一个轻量级的PHP的Excel操作库-PHP_XLSXWriter 10w行excel数据导出仅需要5.26秒,再也不用担心excel ...

  5. 「建议心心」要就来15道多线程面试题一次爽到底(1.1w字用心整理)

    . 本文是给**「建议收藏」200MB大厂面试文档,整理总结2020年最强面试题库「CoreJava篇」**写的答案,所有相关文章已经收录在码云仓库:https://gitee.com/bingqil ...

  6. 关于MySQL数据库事务的机制学习总结

    这几天面试多次被问到了数据库事务机制.隔离级别.乐观锁悲观锁类的问题,之前对这些只能说有所了解,有些概念还停留在记忆层面,没有理解,所以回答的不好.后面翻书学习了下,理解了一些东西,在此做一个记录. ...

  7. SpringBoot启动的时候出现log4j警告(配置文件找不到)

    SpringBoot启动的时候报如下的警告 在启动SpringBoot项目的时候,idea出现如下警告信息,也就是log4j 配置文件找不到的问题 log4j:WARN No appenders co ...

  8. Python:(使用matplotlib画图)次坐标轴,两个坐标轴

    https://blog.csdn.net/Poul_henry/article/details/82533569

  9. Python中保留两位小数的几种方法

    https://blog.csdn.net/Jerry_1126/article/details/85009810 保留两位小数,并做四舍五入处理方法一: 使用字符串格式化>>> a ...

  10. 机器学习之强化学习概览(Machine Learning for Humans: Reinforcement Learning)

    声明:本文翻译自Vishal Maini在Medium平台上发布的<Machine Learning for Humans>的教程的<Part 5: Reinforcement Le ...