美文网首页
【Linux】/proc/stat详解 完整验证版

【Linux】/proc/stat详解 完整验证版

作者: blue_smile | 来源:发表于2018-06-14 20:52 被阅读0次

    最初是想参考网上的文档完成自己的功能,却由于网上的解释不全,自己看man文档。读了文档后发现网上文档的部分解决是存在问题的,遂将这里的相关信息进行梳理以作备用,并分享给大家。希望也能对大家有帮助。

    /proc/stat中包含系统启动以来的很多系统和内核的统计信息,平时大家比较关心的比如包括CPU运行情况、中断情况、启动时间、上线文切换次数、运行中的进程等信息都在其中。

    一、文件全貌

    # Linux下查看/proc/stat的具体信息如下
    [root@WSC-31-2 ~]# cat /proc/stat 
    cpu  60382 1 80032 198934063 2349 0 109 0 0 0
    cpu0 2405 0 2084 4140924 682 0 6 0 0 0
    ...  # 此处较多冗余信息,简化之
    cpu47 200 0 134 4147222 10 0 0 0 0 0
    
    intr 33622492 64 ... 0 0 0 0 # 此处较多冗余信息,简化之
    ctxt 68533835
    btime 1528905555
    processes 318904
    procs_running 1
    procs_blocked 0
    softirq 16567860 0 3850777 8555 5448802 116727 0 1 3577293 1290 3564415
    

    这里将上述内容划分成几个模块进行分析

    二、字段含义分析

    name   user  nice   system      idle      iowait  irrq  softirq  steal guest guest_nice 
    cpu    60382   1     80032     198934063   2349     0     109      0     0       0
    cpu0   2405    0     2084      4140924     682      0     6        0     0       0
    ...  # 此处较多冗余信息,简化之
    cpu47  200     0     134       4147222     10       0     0        0     0       0
    
    cpu指标 含义 时间单位 备注
    user 用户态时间 jiffies 一般/高优先级,仅统计nice<=0
    nice nice用户态时间 jiffies 低优先级,仅统计nice>0
    system 内核态时间 jiffies
    idle 空闲时间 jiffies 不包含IO等待时间
    iowait I/O等待时间 jiffies 硬盘IO等待时间
    irq 硬中断时间 jiffies
    softirq 软中断时间 jiffies
    steal 被盗时间 jiffies 虚拟化环境中运行其他操作系统上花费的时间(since Linux 2.6.11)
    guest 来宾时间 jiffies 操作系统运行虚拟CPU花费的时间(since Linux 2.6.24)
    guest_nice nice来宾时间 jiffies 运行一个带nice值的guest花费的时间(since Linux 2.6.33)

    说明:

    1、1 jiffies = 0.01s = 10ms
    2、常用计算等式:CPU时间 = user + system + nice + idle + iowait + irq + softirq
    3、man手册中iowait有单独说明,iowait时间是不可靠值,具体原因如下:
    1)CPU不会等待I/O执行完成,而iowait是等待I/O完成的时间。
    当CPU进入idle状态,很可能会调度另一个task执行,所以iowait计算时间偏小;
    2)多核CPU中,iowait的计算并非某一个核,因此计算每一个cpu的iowait非常困难
    3)这个值在某些情况下会减少
    更多信息可以通过man手册查看:http://man7.org/linux/man-pages/man5/proc.5.html


    intr 33622492 64 ... 0 0 0 0 # 此处较多冗余信息,简化之
    # 这行给出中断的信息,第一个为自系统启动以来,发生的所有的中断的次数
    # 然后每个数对应一个特定的中断自系统启动以来所发生的次数。
    
    ctxt 68533835       #自系统启动以来CPU发生的上下文交换的次数
    
    btime 1528905555    #系统启动到现在的时间,单位为秒(s)
    
    processes 318904    #自系统启动以来所创建的任务的个数目
    
    procs_running 1     #当前运行队列的任务的数目
    
    procs_blocked 0     #当前被阻塞的任务的数目
    
    softirq 16567860 0 3850777 8555 5448802 116727 0 1 3577293 1290 3564415
    # 此行显示所有CPU的softirq总数
    # 第一列是所有软件和每个软件的总数
    # 后面的列是特定softirq的总数
    

    技巧

    [root@WSC-31-2 ~]# cat /proc/uptime
    74495.52 3570301.60
    # 第一个参数是开机到现在的时间,单位为秒(s)
    # 第二个参数是开机到现在CPU空闲时间,单位为秒(s)
    
    # 通过下列语句,计算出当前时间
    ut=`cut -d' ' -f1 </proc/uptime` 
    ts=`date +%s` 
    date -d"70-1-1 + $ts sec - $ut sec + 74495.52 sec" +"%F %T"
    

    相关文章

      网友评论

          本文标题:【Linux】/proc/stat详解 完整验证版

          本文链接:https://www.haomeiwen.com/subject/lioeeftx.html