zoukankan      html  css  js  c++  java
  • mpstat命令参数详解

    mpstat
    另一个用于获取 CPU 相关统计信息的有用的命令是 mpstat。下面是一个示例输出:
     
    # mpstat -P ALL 5 2
    Linux 2.6.9-67.ELsmp (oraclerac1)       12/20/2008
     
    10:42:38 PM  CPU   %user   %nice %system %iowait    %irq   %soft   %idle    intr/s
    10:42:43 PM  all    6.89    0.00   44.76    0.10    0.10    0.10   48.05   1121.60
    10:42:43 PM    0    9.20    0.00   49.00    0.00    0.00    0.20   41.60    413.00
    10:42:43 PM    1    4.60    0.00   40.60    0.00    0.20    0.20   54.60    708.40
     
    10:42:43 PM  CPU   %user   %nice %system %iowait    %irq   %soft   %idle    intr/s
    10:42:48 PM  all    7.60    0.00   45.30    0.30    0.00    0.10   46.70   1195.01
    10:42:48 PM    0    4.19    0.00    2.20    0.40    0.00    0.00   93.21   1034.53
    10:42:48 PM    1   10.78    0.00   88.22    0.40    0.00    0.00    0.20    160.48
     
    Average:     CPU   %user   %nice %system %iowait    %irq   %soft   %idle    intr/s
    Average:     all    7.25    0.00   45.03    0.20    0.05    0.10   47.38   1158.34
    Average:       0    6.69    0.00   25.57    0.20    0.00    0.10   67.43    724.08
    Average:       1    7.69    0.00   64.44    0.20    0.10    0.10   27.37    434.17
     
    它显示了系统中 CPU 的各种统计信息。–P ALL 选项指示该命令显示所有 CPU 的统计信息,
    而不只是特定 CPU 的统计信息。参数 5 2 指示该命令每隔 5 秒运行一次,共运行 2 次。
    以上输出首先显示了所有 CPU 的合计指标,然后显示了每个 CPU 各自的指标。最后,在结尾处显示所有 CPU 的平均值。
     
    让我们看一看这些列值的含义:
     
     
    %user     表示处理用户进程所使用 CPU 的百分比。用户进程是用于应用程序(如 Oracle 数据库)的非内核进程。
              在本示例输出中,用户 CPU 百分比非常低。
     
    %nice     表示使用 nice 命令对进程进行降级时 CPU 的百分比。在之前的部分中已经对 nice 命令进行了介绍。简单来说,nice 命令更改进程的优先级。
     
    %system   表示内核进程使用的 CPU 百分比
     
    %iowait   表示等待进行 I/O 所使用的 CPU 时间百分比
     
    %irq      表示用于处理系统中断的 CPU 百分比
     
    %soft     表示用于软件中断的 CPU 百分比
     
    %idle     显示 CPU 的空闲时间
     
    %intr/s   显示每秒 CPU 接收的中断总数
     
    当您拥有前面所述的 vmstat 时,您可能想知道 mpstat 命令的作用。差别很大:mpstat 可以显示每个处理器的统计,
    而 vmstat 显示所有处理器的统计。因此,编写糟糕的应用程序(不使用多线程体系结构)可能会运行在一个多处理器机器上,
    而不使用所有处理器。从而导致一个 CPU 过载,而其他 CPU 却很空闲。通过 mpstat 可以轻松诊断这些类型的问题。
     
    针对 Oracle 用户的用法
       与 vmstat 相似,mpstat 命令还产生与 CPU 有关的统计信息,因此所有与 CPU 问题有关的讨论也都适用于 mpstat。
    当您看到较低的 %idle 数字时,您知道出现了 CPU 不足的问题。当您看到较高的 %iowait 数字时,
    您知道在当前负载下 I/O 子系统出现了某些问题。该信息对于解决 Oracle 数据库性能问题非常方便。
    

      

    mpstat是 Multiprocessor Statistics的缩写,是实时系统监控工具。其报告与CPU的一些统计信息,这些信息存放在/proc/stat文件中。在多CPU系统里,其不但能查看所有CPU的平均状况信息,而且能够查看特定CPU的信息。

    mpstat的语法如下
    mpstat [-P {cpu|ALL}] [internal [count]]
     

    其中,各参数含义如下:

    参数 含义
    -P {cpu l ALL} 表示监控哪个CPU, cpu在[0,cpu个数-1]中取值
    internal 相邻的两次采样的间隔时间
    count 采样的次数,count只能和delay一起使用
    使用mpstat命令
    1.直接使用mpstat命令:

    mpstat

    当mpstat不带参数时,输出为从系统启动以来的平均值。

    2.使用mpstat -P ALL 5 2命令

    mpstat -P ALL 5 2


    表示每5秒产生一个报告,总共产生2个。


    上图表示每5秒产生了2个关于处理器的统计数据报告,一共产生2个interval 的信息,然后再给出这2个interval的平均信息。默认时,输出是按照CPU 号排序。第一个行给出了从系统引导以来的所有活跃数据。接下来每行对应一个处理器的活跃状态。

    输出参数含义
    当没有参数时,mpstat则显示系统启动以后所有信息的平均值。有interval时,第一行的信息自系统启动以来的平均信息。从第二行开始,输出为前一个interval时间段的平均信息。

    输出各参数含义:

    参数 释义 从/proc/stat获得数据
    CPU 处理器ID
    %usr 在internal时间段里,用户态的CPU时间(%),不包含 nice值为负进程 usr/total*100
    %nice 在internal时间段里,nice值为负进程的CPU时间(%) nice/total*100
    %sys 在internal时间段里,核心时间(%) system/total*100
    %iowait 在internal时间段里,硬盘IO等待时间(%) iowait/total*100
    %irq 在internal时间段里,硬中断时间(%) irq/total*100
    %soft 在internal时间段里,软中断时间(%) softirq/total*100
    %steal 显示虚拟机管理器在服务另一个虚拟处理器时虚拟CPU处在非自愿等待下花费时间的百分比 steal/total*100
    %guest 显示运行虚拟处理器时CPU花费时间的百分比 guest/total*100
    %gnice gnice/total*100
    %idle 在internal时间段里,CPU除去等待磁盘IO操作外的因为任何原因而空闲的时间闲置时间(%) idle/total*100

    CPU总的工作时间:

    total_cur = user + system + nice + idle + iowait + irq + softirq

    total_pre = pre_user + pre_system + pre_nice + pre_idle + pre_iowait + pre_irq + pre_softirq

    user = user_cur – user_pre

    total = total_cur - total_pre

    其中_cur 表示当前值,_pre表示interval时间前的值。上表中的所有值可取到两位小数点。

    Note:
    1.vmstat和mpstat 命令的差别:mpstat 可以显示每个处理器的统计,而 vmstat 显示所有处理器的统计。因此,编写糟糕的应用程序(不使用多线程体系结构)可能会运行在一个多处理器机器上,而不使用所有处理器。从而导致一个 CPU 过载,而其他 CPU 却很空闲。通过 mpstat 可以轻松诊断这些类型的问题。

    2.vmstat中所有关于CPU的总结都适合mpstat。当您看到较低的 %idle 数字时,您知道出现了 CPU 不足的问题。当您看到较高的 %iowait 数字时,您知道在当前负载下 I/O 子系统出现了某些问题。

    参考:

    https://blog.csdn.net/evils798/article/details/7524474

  • 相关阅读:
    Java并发编程:同步容器
    poj 1961 Period
    html与JacaScript中的重要思想:预留后路、向后兼容、js分离
    SQL从头開始
    android帧动画,移动位置,缩放,改变透明度等动画解说
    COCOS学习笔记--Cocod2dx内存管理(三)-Coco2d-x内存执行原理
    构建基于Javascript的移动CMS——生成博客(二).路由
    Oracle 单表选择率
    刚接触Joomla,写一下瞎折腾的初感受~
    Android学习笔记之ProgressBar案例分析
  • 原文地址:https://www.cnblogs.com/MLing/p/14609836.html
Copyright © 2011-2022 走看看