系统基础信息采集模块作为监控模块的重要组成部分,能够帮助运维人员了解当前系统的健康程度,同时也是衡量业务的服务质量的依据,比如系统资源吃紧,会直接影响业务的服务质量及用户体验,另外获取设备的流量信息,也可以让运维人员更好地评估带宽、设备资源是否应该扩容。运用Python第三方系统基础模块,可以轻松获取服务关键运营指标数据,包括Linux基本性能、块设备、网卡接口、系统信息、网络地址库等信息。在采集到这些数据后,我们就可以全方位了解系统服务的状态,再结合告警机制,可以在第一时间响应,将异常现在苗头时就得以处理。
psutil模块
psutil是一个跨平台库(http://code.google.com/p/psutil/),能够轻松实现获取系统运行的进程和系统利用率(包括CPU、内存、磁盘、网络等)信息。它主要应用于系统监控,分析和限制系统资源及进程的管理。它实现了同等命令行工具提供的功能,如ps、top、lsof、netstat、ifconfig、who、df、kill、free、nice、ionice、iostat、iotop、uptime、pidof、tty、taskset、pmap等。目前支持32位和64位的Linux、Windows、OS X、FreeBSD和Sun Solaris等操作系统,支持从2.4到3.4的Python版本。
一、获取系统性能信息
采集系统基本性能信息
系统基本信息主要包含CPU、内存、磁盘、网络等,可以很好的描述服务器资源使用情况,对于我们运维人员分析资源使用等有重要作用。psutil模块已经封装了这些方法,可以根据我们的需求完成调用和实际应用。
(1)CPU信息
Linux操作系统CPU利用率有以下几个部分
Usertime 执行用户进程的时间百分比:
Systemtime 执行内核进程和中断的时间百分比:
Wait IO 由于IO等待而使CPU处于idle(空闲)状态的时间百分比;
Idle CPU处于idle状态的时间百分比
Linux Shell命令获取以上信息
python psutil模块实现
很简单的就可以得到我们想要的数据,输出结果是一个元组我们可以使用切片得到具体的值。
获取CPU数量
psutil.cpu_count() #逻辑个数psutil.cpu_count(logical=False) #物理个数
内存信息
Linux系统的内存利用率信息涉及total(内存总数)、used(已使用的内存数)、free(空闲内存数)、buffers(缓冲使用数)、cache(缓存使用数)、swap(交换分区使用数)等,分别使用psutil.virtual_memory()与psutil.swap_memory()方法获取这些信息。
获取完整信息
psutil.virtual_memory()
结果
Swap参数获取
磁盘信息
在系统的所有磁盘信息中,我们更加关注磁盘的利用率及IO信息,其中磁盘利用率使psutil.disk_usage()方法获取。磁盘IO信息包括read_count(读IO数)、write_count(写IO数)、read_bytes(IO读字节数)、write_bytes(IO写字节数)、read_time(磁盘读时间)、write_time(磁盘写时间)等。这些IO信息可以使用psutil.disk_io_counters()获取
例如
网络信息
系统的网络信息与磁盘IO类似,涉及几个关键点,包括bytes_sent(发送字节数)、bytes_recv=28220119(接收字节数)、packets_sent=200978(发送数据包数)、packets_recv=212672(接收数据包数)等。这些网络信息使用psutil.net_io_counters()方法获取
使用psutil.net_io_counters获取网络总的IO信息 默认pernic=False,
当pernic=Ture时可以获取每个网卡的流量信息
用户信息与开机时间等信息
使用psutil.users方法返回当前登录系统的用户信息
使用psutil.boot_time方法获取开机时间,以Linux时间戳格
进程管理
获得当前系统的进程信息,可以让运维人员得知应用程序的运行状态,包括进程的启动时间、查看或设置CPU亲和度、内存使用率、IO信息、socket连接、线程数等,这些信息可以呈现出指定进程是否存活、资源利用情况,为开发人员的代码优化、问题定位提供很好的数据参考。
进程信息
psutil模块在获取进程信息方面也提供了很好的支持,包括使用psutil.pids()方法获取所有进程PID,使用psutil.Process()方法获取单个进程的名称、路径、状态、系统资源利用率等信息。
我们可以使用进程ID和 psutil.Process()方法将某个进程实例化,这样就能得到更多的信息例如我们将ID为270实例化