进程实时监控pidstat命令详解
发布日期:2021-09-11 05:52:36 浏览次数:33 分类:技术文章

本文共 2907 字,大约阅读时间需要 9 分钟。

pidstat主要用于监控全部或指定进程占用系统资源的情况,如CPU,内存、设备IO、任务切换、线程等。pidstat首次运行时显示自系统启动开始的各项统计信息,之后运行pidstat将显示自上次运行该命令以后的统计信息。用户可以通过指定统计的次数和时间来获得所需的统计信息。

实例讲解

默认参数

执行pidstat,将输出系统启动后所有活动进程的cpu统计信息:

$ pidstat 1Linux 3.13.0-49-generic (titanclusters-xxxxx) 07/14/2015 _x86_64_ (32 CPU)07:41:02 PM UID PID %usr %system %guest %CPU CPU Command07:41:03 PM 0 9 0.00 0.94 0.00 0.94 1 rcuos/007:41:03 PM 0 4214 5.66 5.66 0.00 11.32 15 mesos-slave07:41:03 PM 0 4354 0.94 0.94 0.00 1.89 8 java07:41:03 PM 0 6521 1596.23 1.89 0.00 1598.11 27 java07:41:03 PM 0 6564 1571.70 7.55 0.00 1579.25 28 java07:41:03 PM 60004 60154 0.94 4.72 0.00 5.66 9 pidstat07:41:03 PM UID PID %usr %system %guest %CPU CPU Command07:41:04 PM 0 4214 6.00 2.00 0.00 8.00 15 mesos-slave07:41:04 PM 0 6521 1590.00 1.00 0.00 1591.00 27 java07:41:04 PM 0 6564 1573.00 10.00 0.00 1583.00 28 java07:41:04 PM 108 6718 1.00 0.00 0.00 1.00 0 snmp-pass07:41:04 PM 60004 60154 1.00 4.00 0.00 5.00 9 pidstat

pidstat命令输出进程的CPU占用率,该命令会持续输出,并且不会覆盖之前的数据,可以方便观察系统动态。如上的输出,可以看见两个JAVA进程占用了将近1600%的CPU时间,既消耗了大约16个CPU核心的运算资源。

指定采样周期和采样次数

pidstat命令指定采样周期和采样次数,命令形式为”pidstat [option] interval [count]”,以下pidstat输出以2秒为采样周期,输出10次cpu使用统计信息:

pidstat 2 10

cpu使用情况统计(-u)

使用-u选项,pidstat将显示各活动进程的cpu使用统计,执行”pidstat -u”与单独执行”pidstat”的效果一样。

 

内存使用情况统计(-r)

使用-r选项,pidstat将显示各活动进程的内存使用统计:

linux:~ # pidstat -r -p 13084 1Linux 2.6.32.12-0.7-default (linux)             06/18/12        _x86_64_15:08:18          PID  minflt/s  majflt/s     VSZ    RSS   %MEM  Command15:08:19        13084 133835.00      0.00 15720284 15716896  96.26  mmmm15:08:20        13084  35807.00      0.00 15863504 15849756  97.07  mmmm15:08:21        13084  19273.87      0.00 15949040 15792944  96.72  mmmm

以上各列输出的含义如下:

minflt/s: 每秒次缺页错误次数(minor page faults),次缺页错误次数意即虚拟内存地址映射成物理内存地址产生的page fault次数majflt/s: 每秒主缺页错误次数(major page faults),当虚拟内存地址映射成物理内存地址时,相应的page在swap中,这样的page fault为major page fault,一般在内存使用紧张时产生VSZ:      该进程使用的虚拟内存(以kB为单位)RSS:      该进程使用的物理内存(以kB为单位)%MEM:     该进程使用内存的百分比Command:  拉起进程对应的命令

IO情况统计(-d)

使用-d选项,我们可以查看进程IO的统计信息:

linux:~ # pidstat -d 1 2Linux 2.6.32.12-0.7-default (linux)             06/18/12        _x86_64_17:11:36          PID   kB_rd/s   kB_wr/s kB_ccwr/s  Command17:11:37        14579 124988.24      0.00      0.00  dd17:11:37          PID   kB_rd/s   kB_wr/s kB_ccwr/s  Command17:11:38        14579 105441.58      0.00      0.00  dd

输出信息含义

kB_rd/s: 每秒进程从磁盘读取的数据量(以kB为单位)kB_wr/s: 每秒进程向磁盘写的数据量(以kB为单位)Command: 拉起进程对应的命令

针对特定进程统计(-p)

使用-p选项,我们可以查看特定进程的系统资源使用情况:

linux:~ # pidstat -r -p 1 1Linux 2.6.32.12-0.7-default (linux)             06/18/12        _x86_64_18:26:17          PID  minflt/s  majflt/s     VSZ    RSS   %MEM  Command18:26:18            1      0.00      0.00   10380    640   0.00  init18:26:19            1      0.00      0.00   10380    640   0.00  init……

pidstat常用命令

使用pidstat进行问题定位时,以下命令常被用到:

pidstat -u 1pidstat -r 1pidstat -d 1

以上命令以1秒为信息采集周期,分别获取cpu、内存和磁盘IO的统计信息。

转载地址:https://blog.csdn.net/weixin_34406061/article/details/85997309 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:015-Go 数据库操作注意事项
下一篇:python3 钉钉群机器人 webhook

发表评论

最新留言

不错!
[***.144.177.141]2024年03月29日 06时53分04秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

助力职场的这4项软技能很重要 2019-04-27
binlog server伪装master恢复增量数据 2019-04-27
最受欢迎的微服务框架概览 2019-04-27
自己动手写SQL执行引擎 2019-04-27
关于数据库、数据治理、AIOps的这些痛点,你需要知道! | DAMS 2020 2019-04-27
MySQL流转工具Maxwell的代码改造和优化小结 2019-04-27
互动赠书:简历中常见的问题,献给1024的骚年 2019-04-27
与 DevOps 面对面 2019-04-27
CPU占用又爆了?MySQL到底在干什么 2019-04-27
招贤纳士-第17期,来自北京,西安的职位 2019-04-27
秋招拿了7个offer,分享一些反思和经验 2019-04-27
一文带你深扒ClassLoader内核,揭开它的神秘面纱! 2019-04-27
看GitHub 2020年度报告有感 2019-04-27
MySQL如何管理客户端连接?线程池篇 2019-04-27
VScode 折叠函数快捷键 合上函数 2019-04-27
智能家居传感器:BME680--树莓派3B+ 搭配BME680的数据读取温湿度和气压。树莓派IIC BME680算法库 (未完成版本) 2019-04-27
domoticz智能家居系统 MQTT 异常以及解决方法 code=14 2019-04-27
智能家居传感器:BME680--树莓派3B+ 搭配BME680的数据读取温湿度和气压。树莓派IIC BME680算法库完整版 2019-04-27
lua语言笔记--注册dll内的函数到全局,lua 全局函数的注册 2019-04-27
工作笔记::c++ 运行命令行脚本 启动lua cmd lua 顺序执行多个文件的方法 c++ 开启一个命令行的方法 lua 启动多个文件 2019-04-27