pidstat 概述

  1. pidstatsysstat工具的一个命令,用于监控全部或指定进程的cpu、内存、线程、设备IO等系统资源的占用情况。pidstat首次运行时显示自系统启动开始的各项统计信息,之后运行pidstat将显示自上次运行该命令以后的统计信息。用户可以通过指定统计的次数和时间来获得所需的统计信息。
常用的参数 解释
-u  默认的参数,显示各个进程的cpu使用统计
 -r 显示各个进程的内存使用统计
-d 显示各个进程的IO使用情况 
-p 指定进程号
-w 显示每个进程的上下文切换情况
-t  显示选择任务的线程的统计信息外的额外信息
-T{TASK或CHILD或ALL}   这个选项指定了pidstat监控的。TASK表示报告独立的task,CHILD关键字表示报告进程下所有线程统计信息。ALL表示报告独立的task和task下面的所有线程。
-V 版本号
-h  在一行上显示了所有活动,这样其他程序可以容易解析
 -I(大写的i) 在SMP环境,表示任务的CPU使用率/内核数量
-l  显示命令名和所有参数
正确使用该命令 要理解几个特殊的字段:
名称 解释
pid 进程ID
lwp 线程ID。在用户态的命令(比如ps)中常用的显示方式
tid 线程ID,等于lwp。tid在系统提供的接口函数中更常用,比如syscall(SYS_gettid)和syscall(__NR_gettid)
tgid 线程组ID,也就是线程组leader的进程ID,等于pid。
pgid 进程组ID,也就是进程组leader的进程ID。
pthread id pthread库提供的ID,生效范围不在系统级别,可以忽略。
sid session ID for the session leader。
tpgid tty process group ID for the process group leader
下面介绍一下各个命令 返回字段的含义:
  1. pidstat -u -p pid

 

  1. PID:进程ID
  2. %usr:进程在用户空间占用cpu的百分比
  3. %system:进程在内核空间占用cpu的百分比
  4. %guest:进程在虚拟机占用cpu的百分比
  5. %CPU:进程占用cpu的百分比
  6. CPU:处理进程的cpu编号
  7. Command:当前进程对应的命令
  1. pidstat -r -p pid

 

  1. PID:进程标识符
  2. Minflt/s:任务每秒发生的次要错误,不需要从磁盘中加载页
  3. Majflt/s:任务每秒发生的主要错误,需要从磁盘中加载页
  4. VSZ:虚拟地址大小,虚拟内存的使用KB
  5. RSS:常驻集合大小,非交换区五里内存使用KB
  6. Commandtask命令名
  1. pidstat -d -p pid

   

  1. PID:进程id
  2. kB_rd/s:每秒从磁盘读取的KB
  3. kB_wr/s:每秒写入磁盘KB
  4. kB_ccwr/s:任务取消的写入磁盘的KB。当任务截断脏的pagecache的时候会发生。
  5. COMMAND:task的命令名
  1. pidstat -w -p pid

  

  1. PID:进程id
  2. Cswch/s:每秒主动任务上下文切换数量
  3. Nvcswch/s:每秒被动任务上下文切换数量
  4. Command:命令名
  1. pidstat -t -p pid

  

  1. TGID:主线程的表示
  2. TID:线程id
  3. %usr:进程在用户空间占用cpu的百分比
  4. %system:进程在内核空间占用cpu的百分比
  5. %guest:进程在虚拟机占用cpu的百分比
  6. %CPU:进程占用cpu的百分比
  7. CPU:处理进程的cpu编号
  8. Command:当前进程对应的命令
  1. pidstat -T ALL -p pid

  

  1. PID:进程id
  2. Usr-ms:任务和子线程在用户级别使用的毫秒数。
  3. System-ms:任务和子线程在系统级别使用的毫秒数。
  4. Guest-ms:任务和子线程在虚拟机(running a virtual processor)使用的毫秒数。
  5. Command:命令名

性能分析案例

这里以分析的java程序的为案例:

  • 1、查找到你所观察程序的进程号
  1. jps -l

  

  • 2、获取进程pid之后 查看该进程的cpu 使用情况:
  1. pidstat -u -p 15173 1

  

  • 3、 假如该进程的cpu使用率过高 通过更细粒度的命令进行观察:
  1. pidstat -t -p 15173 1

  

  • 4、定位到占用cpu使用频率过高的线程 例如上图(这里是假如)15181 然后通过 jstack - l 15181 >/tmp/15181.txt 将线程数据导出 即可分析结果
  • 5、这个方法可以很准确的定位到是java的那个方法出了问题 占用cpu过高

  

性能测试-pidstat 问题定位分析的更多相关文章

  1. 性能测试培训:定位jvm耗时函数

    性能测试培训:定位jvm耗时函数   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq:90882 ...

  2. LCD 显示异常定位分析方法

    第一种情况: 进入kernel或android 后,如果LCM图像示异常,可以通过如下步骤来判断问题出现在哪个层面. step1:通过DMMS截图,来判断上面刷到LCM的数据是否有问题. 若DMMS获 ...

  3. 【原创】大叔案例分享(4)定位分析--见证scala的强大

    一 场景分析 定位分析广泛应用,比如室外基站定位,室内蓝牙beacon定位,室内wifi探针定位等,实现方式是三点定位 Trilateration 理想情况 这种理想情况要求3个基站‘同时’采集‘准确 ...

  4. [转][LoadRunner]LR性能测试结果样例分析

    LR性能测试结果样例分析 测试结果分析 LoadRunner性能测试结果分析是个复杂的过程,通常可以从结果摘要.并发数.平均事务响应时间.每秒点击数.业务成功率.系统资源.网页细分图.Web服务器资源 ...

  5. [LoadRunner]LR性能测试结果样例分析

    R性能测试结果样例分析 测试结果分析 LoadRunner性能测试结果分析是个复杂的过程,通常可以从结果摘要.并发数.平均事务响应时间.每秒点击数.业务成功率.系统资源.网页细分图.Web服务器资源. ...

  6. Java:死锁编码及定位分析

    Java:死锁编码及定位分析 本笔记是根据bilibili上 尚硅谷 的课程 Java大厂面试题第二季 而做的笔记 概念 死锁是指两个或多个以上的进程在执行过程中,因争夺资源而造成一种互相等待的现象, ...

  7. 性能测试day07_性能瓶颈和分析

    其实如果之前都做的很到位的话,那么再加上APM工具(dynaTrace等),监控到非常细节,那么我们跑一个业务,我们就能完全清楚的知道每个请求的时间,也能知道请求所产生sql的时间,这样你自然而然都知 ...

  8. 转:LR性能测试结果样例分析 测试结果分析

    LoadRunner性能测试结果分析是个复杂的过程,通常可以从结果摘要.并发数.平均事务响应时间.每秒点击数.业务成功率.系统资源.网页细分图.Web服务器资源.数据库服务器资源等几个方面分析,如图1 ...

  9. LR性能测试结果样例分析

    http://www.cnblogs.com/hyzhou/archive/2011/11/16/2251316.html   测试结果分析 LoadRunner性能测试结果分析是个复杂的过程,通常可 ...

随机推荐

  1. C 最大公约数&最小公倍数

    1.最大公约数  链接 如果有一个自然数a能被自然数b整除,则称a为b的倍数,b为a的约数.几个自然数公有的约数,叫做这几个自然数的公约数.公约数中最大的一个公约数,称为这几个自然数的最大公约数. 1 ...

  2. Python——Pandas库入门

    一.Pandas库介绍 Pandas是Python第三方库,提供高性能易用数据类型和分析工具 import pandas as pd Pandas基于NumPy实现,常与NumPy和Matplotli ...

  3. Java系列之泛型

    自从 JDK 1.5 提供了泛型概念,泛型使得开发者可以定义较为安全的类型,不至于强制类型转化时出现类型转化异常,在没有反省之前,可以通过 Object 来完成不同类型数据之间的操作,但是强制类型转换 ...

  4. 新基建新机遇!100页PPT

    "新基建"是与传统的"铁公基"相对应,结合新一轮科技革命和产业变革特征,面向国家战略需求,为经济社会的创新.协调.绿色.开放.共享发展提供底层支撑的具有乘数效应 ...

  5. A 修公路

    时间限制 : - MS   空间限制 : 65536 KB  评测说明 : 时限1000ms 问题描述 某岛国有n个小岛构成(编号1到n),该国政府想要通过n-1条双向公路将这些小岛连接起来,使得任意 ...

  6. Apache本地服务器搭建(Mac版)

    由于Mac自带apache服务器,所以无需下载,apache默认处于开启状态. 可以在浏览器输入localhost,显示It works!,代表目前处于开启状态,默认文件目录为/Library/Web ...

  7. 别人家的 InfluxDB 实战 + 源码剖析

    1. 前几次的分享,我们多次提到了下图中 Metrics 指标监控的 Prometheus.Grafana,而且 get 到了 influxdata 旗下的 InfluxDB 的入门技能. 本次,我们 ...

  8. iOS - scrollView与headerView的视差滚动实现思路

    假设场景:viewController里面有一个scrollView,该scrollView有一个headerView.现在需要将scrollView的滚动contentOffset与headerVi ...

  9. Github使用SSH的步骤

    1) 打开git bash命令行工具 2) 输入下面命令生成一对私钥和公钥 ssh-keygen -t rsa -b 4096 -C "你的github的邮箱" 3) 输入公钥和私 ...

  10. rest_framework-序列化-1

    序列化 定义模型类 from django.db import models # Create your models here. class StuModel(models.Model): SEX_ ...