linux性能分析命令--pidstat

简介

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

安装

yum install sysstat -y

命令参数

pidstat [ 选项 ] [ <时间间隔> ] [ <次数> ]
常用的参数:

  • u:默认的参数,显示各个进程的cpu使用统计
  • r:显示各个进程的内存使用统计
  • d:显示各个进程的IO使用情况
  • p:指定进程号
  • w:显示每个进程的上下文切换情况
  • t:显示选择任务的线程的统计信息外的额外信息
  • T { TASK | CHILD | ALL }
    这个选项指定了pidstat监控的。TASK表示报告独立的task,CHILD关键字表示报告进程下所有线程统计信息。ALL表示报告独立的task和task下面的所有线程。
    注意:task和子线程的全局的统计信息和pidstat选项无关。这些统计信息不会对应到当前的统计间隔,这些统计信息只有在子线程kill或者完成的时候才会被收集。
  • V:版本号
  • h:在一行上显示了所有活动,这样其他程序可以容易解析。
  • I:在SMP环境,表示任务的CPU使用率/内核数量
  • l:显示命令名和所有参数

具体用法

1、pidstat 默认显示所有进程的cpu使用情况

等同于pidstat -u -p ALL,等同于pidstat -u

[root@vircent7 ~]# pidstat
Linux 3.10.0-1160.45.1.el7.x86_64 (vircent7.kyj)        2021年12月15日  _x86_64_        (4 CPU)

14时19分24秒   UID       PID    %usr %system  %guest    %CPU   CPU  Command
14时19分24秒     0         1    0.00    0.04    0.00    0.04     1  systemd
14时19分24秒     0         2    0.00    0.00    0.00    0.00     0  kthreadd
14时19分24秒     0         6    0.00    0.00    0.00    0.00     0  ksoftirqd/0
14时19分24秒     0         7    0.00    0.00    0.00    0.00     0  migration/0
14时19分24秒     0         9    0.00    0.02    0.00    0.02     3  rcu_sched
  • PID:进程ID
  • %usr:进程在用户空间占用cpu的百分比
  • %system:进程在内核空间占用cpu的百分比
  • %guest:进程在虚拟机占用cpu的百分比
  • %CPU:进程占用cpu的百分比
  • CPU:处理进程的cpu编号
  • Command:当前进程对应的命令
2、pidstat -r 内存使用情况统计

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

[root@vircent7 ~]# pidstat -r
Linux 3.10.0-1160.45.1.el7.x86_64 (vircent7.kyj)        2021年12月15日  _x86_64_        (4 CPU)

15时09分03秒   UID       PID  minflt/s  majflt/s     VSZ    RSS   %MEM  Command
15时09分03秒     0         1      1.02      0.00  128340   6960   0.37  systemd
15时09分03秒     0       591      0.34      0.00   39056   3312   0.18  systemd-journal
15时09分03秒     0       616      0.10      0.00  201128   8128   0.43  lvmetad
15时09分03秒     0       628      0.19      0.00   49052   5504   0.29  systemd-udevd
15时09分03秒     0       721      0.01      0.00   55532    856   0.05  auditd

  • 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: 拉起进程对应的命令
3、pidstat -d IO情况统计

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

[root@vircent7 ~]# pidstat -d
Linux 3.10.0-1160.45.1.el7.x86_64 (vircent7.kyj)        2021年12月15日  _x86_64_        (4 CPU)

15时14分13秒   UID       PID   kB_rd/s   kB_wr/s kB_ccwr/s  Command
15时14分13秒     0         1      5.25      0.16      0.07  systemd
15时14分13秒     0       509      0.00      0.00      0.00  xfsaild/dm-0
15时14分13秒     0       591      0.07      0.00      0.00  systemd-journal
15时14分13秒     0       616      0.00      0.00      0.00  lvmetad
15时14分13秒     0       628      0.79      0.00      0.00  systemd-udevd
15时14分13秒     0       721      0.01      0.03      0.00  auditd
  • kB_rd/s:每秒从磁盘读取的KB
  • kB_wr/s:每秒写入磁盘KB
  • kB_ccwr/s:任务取消的写入磁盘的KB。当任务截断脏的pagecache的时候会发生。
  • COMMAND:task的命令名
4、pidstat -w 显示每个进程的上下文切换情况

[root@vircent7 ~]# pidstat -w
Linux 3.10.0-1160.45.1.el7.x86_64 (vircent7.kyj) 2021年12月15日 x86_64 (4 CPU)

15时16分24秒   UID       PID   cswch/s nvcswch/s  Command
15时16分24秒     0         1      0.15      0.15  systemd
15时16分24秒     0         2      0.02      0.00  kthreadd
15时16分24秒     0         4      0.00      0.00  kworker/0:0H
15时16分24秒     0         6      0.08      0.00  ksoftirqd/0
  • Cswch/s:每秒主动任务上下文切换数量
  • Nvcswch/s:每秒被动任务上下文切换数量
5、使用-t和-p选项显示指定进程的线程
[root@vircent7 ~]# pidstat -r -t -p 2602
Linux 3.10.0-1160.45.1.el7.x86_64 (vircent7.kyj)        2021年12月15日  _x86_64_        (4 CPU)

15时22分19秒   UID      TGID       TID  minflt/s  majflt/s     VSZ    RSS   %MEM  Command
15时22分19秒     0      2602         -      4.27      0.01 2893612 405348  21.54  java
15时22分19秒     0         -      2602      0.08      0.00 2893612 405348  21.54  |__java
15时22分19秒     0         -      2603      0.24      0.00 2893612 405348  21.54  |__java
15时22分19秒     0         -      2604      0.03      0.00 2893612 405348  21.54  |__java
15时22分19秒     0         -      2605      0.02      0.00 2893612 405348  21.54  |__java
  • TGID:主线程id
  • TID: 线程id
6、使用-C和-G选项显示符合匹配的进程
[root@vircent7 ~]# pidstat -r -C java
Linux 3.10.0-1160.45.1.el7.x86_64 (vircent7.kyj)        2021年12月15日  _x86_64_        (4 CPU)

15时23分49秒   UID       PID  minflt/s  majflt/s     VSZ    RSS   %MEM  Command
15时23分49秒     0      2602      4.24      0.01 2893612 405348  21.54  java

对监控对象进行筛选

7、设定采样次数和间隔

以上所有命令结尾,加上两个数字,即可设定采样间隔和采样次数

[root@vircent7 ~]# pidstat -r -C java 1 5
Linux 3.10.0-1160.45.1.el7.x86_64 (vircent7.kyj)        2021年12月15日  _x86_64_        (4 CPU)

15时25分54秒   UID       PID  minflt/s  majflt/s     VSZ    RSS   %MEM  Command

15时25分55秒   UID       PID  minflt/s  majflt/s     VSZ    RSS   %MEM  Command

15时25分56秒   UID       PID  minflt/s  majflt/s     VSZ    RSS   %MEM  Command
15时25分57秒     0      2602      2.00      0.00 2893612 405348  21.54  java

15时25分57秒   UID       PID  minflt/s  majflt/s     VSZ    RSS   %MEM  Command

15时25分58秒   UID       PID  minflt/s  majflt/s     VSZ    RSS   %MEM  Command

平均时间:   UID       PID  minflt/s  majflt/s     VSZ    RSS   %MEM  Command
平均时间:     0      2602      0.40      0.00 2893612 405348  21.54  java

表示每1秒采集一次数据,一共采集5次

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容