zoukankan      html  css  js  c++  java
  • Linux性能检测常用命令

    uptime 命令

    uptime:打印系统总共运行了多长时间和系统的平均负载。uptime命令可以显示的信息显示依次为:现在时间、系统已经运行了多长时间、目前有多少登陆用户、系统在过去的1分钟、5分钟和15分钟内的平均负载。

    语法:uptime(选项)
    选项:-V:显示指令的版本信息。
    实例:使用uptime命令查看系统负载:
        [root@LinServ-1 ~]# uptime -V    #显示uptime命令版本信息
        procps version 3.2.7
    
        [root@LinServ-1 ~]# uptime
        15:31:30 up 127 days,  3:00,  1 user,  load average: 0.00, 0.00, 0.00
    

     显示内容说明:

    15:31:30             //系统当前时间
    up 127 days,  3:00   //主机已运行时间,时间越大,说明你的机器越稳定。
    1 user               //用户连接数,是总连接数而不是用户数
    load average: 0.00, 0.00, 0.00         // 系统平均负载,统计最近1,5,15分钟的系统平均负载

    那么什么是系统平均负载呢? 系统平均负载是指在特定时间间隔内运行队列中的平均进程数。

    如果每个CPU内核的当前活动进程数不大于3的话,那么系统的性能是良好的。如果每个CPU内核的任务数大于5,那么这台机器的性能有严重问题。

    如果你的linux主机是1个双核CPU的话,当Load Average 为6的时候说明机器已经被充分使用了。

    dmesg 命令

    dmesg:用于检查和控制内核的环形缓冲区。kernel会将开机信息存储在ring buffer中。您若是开机时来不及查看信息,可利用dmesg来查看。开机信息保存在/var/log/dmesg文件里。

    语法:dmesg(选项)
    选项:
        -c:显示信息后,清除ring buffer中的内容;
        -s<缓冲区大小>:预设置为8196,刚好等于ring buffer的大小;
        -n:设置记录信息的层级。
    实例:
    [root@localhost ~]# dmesg | head
    Linux version 2.6.18-348.6.1.el5 (mockbuild@builder17.centos.org) (gcc version 4.1.2 20080704 (Red Hat 4.1.2-54)) #1 SMP Tue May 21 15:34:22 EDT 2013
    BIOS-provided physical RAM map:
     BIOS-e820: 0000000000010000 - 000000000009f400 (usable)
     BIOS-e820: 000000000009f400 - 00000000000a0000 (reserved)
     BIOS-e820: 00000000000f0000 - 0000000000100000 (reserved)
     BIOS-e820: 0000000000100000 - 000000007f590000 (usable)
     BIOS-e820: 000000007f590000 - 000000007f5e3000 (ACPI NVS)
     BIOS-e820: 000000007f5e3000 - 000000007f5f0000 (ACPI data)
     BIOS-e820: 000000007f5f0000 - 000000007f600000 (reserved)
     BIOS-e820: 00000000e0000000 - 00000000e8000000 (reserved)
    

    vmstat 命令

    vmstat:显示虚拟内存状态(“Virtual Memory Statistics”),但是它可以报告关于进程、内存、I/O等系统整体运行状态。

    语法:vmstat(选项)(参数)
    选项:
        -a:显示活动内页;
        -f:显示启动后创建的进程总数;
        -m:显示slab信息;
        -n:头信息仅显示一次;
        -s:以表格方式显示事件计数器和内存状态;
        -d:报告磁盘状态;
        -p:显示指定的硬盘分区状态;
        -S:输出信息的单位。
    参数:
        事件间隔:状态信息刷新的时间间隔;
        次数:显示报告的次数。
    实例:
        vmstat 3
        procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu------
         r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
         0  0    320  42188 167332 1534368    0    0     4     7    1    0  0  0 99  0  0
         0  0    320  42188 167332 1534392    0    0     0     0 1002   39  0  0 100  0  0
         0  0    320  42188 167336 1534392    0    0     0    19 1002   44  0  0 100  0  0
         0  0    320  42188 167336 1534392    0    0     0     0 1002   41  0  0 100  0  0
         0  0    320  42188 167336 1534392    0    0     0     0 1002   41  0  0 100  0  0

    字段说明:

    Procs(进程)

    • r: 运行队列中进程数量,这个值也可以判断是否需要增加CPU。(长期大于1)
    • b: 等待IO的进程数量。

    Memory(内存)

    • swpd: 使用虚拟内存大小,如果swpd的值不为0,但是SI,SO的值长期为0,这种情况不会影响系统性能。
    • free: 空闲物理内存大小。
    • buff: 用作缓冲的内存大小。
    • cache: 用作缓存的内存大小,如果cache的值大的时候,说明cache处的文件数多,如果频繁访问到的文件都能被cache处,那么磁盘的读IO bi会非常小。

    Swap

    • si: 每秒从交换区写到内存的大小,由磁盘调入内存。
    • so: 每秒写入交换区的内存大小,由内存调入磁盘。

    注意:内存够用的时候,这2个值都是0,如果这2个值长期大于0时,系统性能会受到影响,磁盘IO和CPU资源都会被消耗。有些朋友看到空闲内存(free)很少的或接近于0时,就认为内存不够用了,不能光看这一点,还要结合si和so,如果free很少,但是si和so也很少(大多时候是0),那么不用担心,系统性能这时不会受到影响的。

    IO(现在的Linux版本块的大小为1kb)

    • bi: 每秒读取的块数
    • bo: 每秒写入的块数

    注意:随机磁盘读写的时候,这2个值越大(如超出1024k),能看到CPU在IO等待的值也会越大。

    system(系统)

    • in: 每秒中断数,包括时钟中断。
    • cs: 每秒上下文切换数。

    注意:上面2个值越大,会看到由内核消耗的CPU时间会越大。

    CPU(以百分比表示)

    • us: 用户进程执行时间百分比(user time)

    us的值比较高时,说明用户进程消耗的CPU时间多,但是如果长期超50%的使用,那么我们就该考虑优化程序算法或者进行加速。

    • sy: 内核系统进程执行时间百分比(system time)

    sy的值高时,说明系统内核消耗的CPU资源多,这并不是良性表现,我们应该检查原因。

    • wa: IO等待时间百分比

    wa的值高时,说明IO等待比较严重,这可能由于磁盘大量作随机访问造成,也有可能磁盘出现瓶颈(块操作)。

    • id: 空闲时间百分比

    mpstat 命令

    mpstat:主要用于多CPU环境下,它显示各个可用CPU的状态系你想。这些信息存放在/proc/stat文件中。在多CPUs系统里,其不但能查看所有CPU的平均状况信息,而且能够查看特定CPU的信息。

    语法:mpstat(选项)(参数)
    选项:-P:指定CPU编号。
    参数:
        间隔时间:每次报告的间隔时间(秒);
        次数:显示报告的次数。
    实例:
    当mpstat不带参数时,输出为从系统启动以来的平均值。
    mpstat
    Linux 2.6.9-5.31AXsmp (builder.redflag-linux.com) 12/16/2005
    09:38:46 AM CPU %user %nice %system %iowait %irq %soft %idle intr/s
    09:38:48 AM all 23.28 0.00 1.75     0.50 0.00 0.00 74.47 1018.59
    
    
    每2秒产生了2个处理器的统计数据报告:
    
    下面的命令可以每2秒产生了2个处理器的统计数据报告,一共产生三个interval 的信息,然后再给出这三个interval的平均信息。默认时,输出是按照CPU 号排序。第一个行给出了从系统引导以来的所有活跃数据。接下来每行对应一个处理器的活跃状态。。
    mpstat -P ALL 2 3
    Linux 2.6.18-164.el5 (server.sys.com)    01/04/2010
    09:34:20 PM CPU   %user   %nice    %sys %iowait    %irq   %soft %steal   %idle    intr/s
    09:34:22 PM all    0.00    0.00    0.00    0.00    0.00    0.00    0.00 100.00   1001.49
    09:34:22 PM    0    0.00    0.00    0.50    0.00    0.00    0.00    0.00   99.50   1001.00
    09:34:22 PM    1    0.00    0.00    0.00    0.00    0.00    0.00    0.00 100.00      0.00
    
    比较带参数和不带参数的mpstat的结果:
    
    在后台开一个2G的文件
    cat 1.img &
    
    然后在另一个终端运行mpstat命令
    mpstat
    Linux 2.6.18-164.el5 (server.sys.com)    01/04/2010
    10:17:31 PM CPU   %user   %nice    %sys %iowait    %irq   %soft %steal   %idle    intr/s
    10:17:31 PM all    0.07    0.02    0.25    0.21    0.01    0.04    0.00   99.40   1004.57
    
    mpstat
    Linux 2.6.18-164.el5 (server.sys.com)    01/04/2010
    10:17:35 PM CPU   %user   %nice    %sys %iowait    %irq   %soft %steal   %idle    intr/s
    10:17:35 PM all    0.07    0.02    0.25    0.21    0.01    0.04    0.00   99.39   1004.73
    
    mpstat 3 10
    Linux 2.6.18-164.el5 (server.sys.com)    01/04/2010
    10:17:55 PM CPU   %user   %nice    %sys %iowait    %irq   %soft %steal   %idle    intr/s
    10:17:58 PM all   13.12    0.00   20.93    0.00    1.83    9.80    0.00   54.32   2488.08
    10:18:01 PM all   10.82    0.00   19.30    0.83    1.83    9.32    0.00   57.90   2449.83
    10:18:04 PM all   10.95    0.00   20.40    0.17    1.99    8.62    0.00   57.88   2384.05
    10:18:07 PM all   10.47    0.00   18.11    0.00    1.50    8.47    0.00   61.46   2416.00
    10:18:10 PM all   11.81    0.00   22.63    0.00    1.83   11.98    0.00   51.75   2210.60
    10:18:13 PM all    6.31    0.00   10.80    0.00    1.00    5.32    0.00   76.58   1795.33
    10:18:19 PM all    1.75    0.00    3.16    0.75    0.25    1.25    0.00   92.85   1245.18
    10:18:22 PM all   11.94    0.00   19.07    0.00    1.99    8.29    0.00   58.71   2630.46
    10:18:25 PM all   11.65    0.00   19.30    0.50    2.00    9.15    0.00   57.40   2673.91
    10:18:28 PM all   11.44    0.00   21.06    0.33    1.99   10.61    0.00   54.56   2369.87
    Average:     all    9.27    0.00   16.18    0.30    1.50    7.64    0.00   65.11   2173.54
    上两表显示出当要正确反映系统的情况,需要正确使用命令的参数。vmstat 和iostat 也需要注意这一问题。
    

    dstat 命令

    dstat:是一个用来替换vmstatiostatnetstatnfsstatifstat这些命令的工具,是一个全能系统信息统计工具。与sysstat相比,dstat拥有一个彩色的界面,在手动观察性能状况时,数据比较显眼容易观察;而且dstat支持即时刷新,譬如输入dstat 3即每三秒收集一次,但最新的数据都会每秒刷新显示。和sysstat相同的是,dstat也可以收集指定的性能资源,譬如dstat -c即显示CPU的使用情况。

    下载并安装

    方法一
    yum install -y dstat
    
    方法二
    官网下载地址:http://dag.wieers.com/rpm/packages/dstat
    wget http://dag.wieers.com/rpm/packages/dstat/dstat-0.6.7-1.rh7.rf.noarch.rpm
    rpm -ivh dstat-0.6.7-1.rh7.rf.noarch.rpm
    

     使用说明:

    安装完后就可以使用了,dstat非常强大,可以实时的监控cpu、磁盘、网络、IO、内存等使用情况。
    
    直接使用dstat,默认使用的是-cdngy参数,分别显示cpu、disk、net、page、system信息,默认是1s显示一条信息。可以在最后指定显示一条信息的时间间隔,如dstat 5是没5s显示一条,dstat 5 10表示没5s显示一条,一共显示10条。
    [root@iZ23uulau1tZ ~]# dstat
    ----total-cpu-usage---- -dsk/total- -net/total- ---paging-- ---system--
    usr sys idl wai hiq siq| read  writ| recv  send|  in   out | int   csw
      0   0  99   0   0   0|7706B  164k|   0     0 |   0     0 | 189   225
      0   0 100   0   0   0|   0     0 |4436B  826B|   0     0 | 195   248
      1   0  99   0   0   0|   0     0 |4744B  346B|   0     0 | 203   242
      0   0 100   0   0   0|   0     0 |5080B  346B|   0     0 | 206   242
      0   1  99   0   0   0|   0     0 |5458B  444B|   0     0 | 214   244
      1   0  99   0   0   0|   0     0 |5080B  346B|   0     0 | 208   242
    下面对显示出来的部分信息作一些说明: cpu:hiq、siq分别为硬中断和软中断次数。 system:int、csw分别为系统的中断次数(interrupt)和上下文切换(context switch)。 其他的都很好理解。
    语法:dstat [-afv] [options..] [delay [count]]
    选项:
            -c:显示CPU系统占用,用户占用,空闲,等待,中断,软件中断等信息。
    	-C:当有多个CPU时候,此参数可按需分别显示cpu状态,例:-C 0,1 是显示cpu0和cpu1的信息。
    	-d:显示磁盘读写数据大小。
    	-D hda,total:include hda and total。
    	-n:显示网络状态。
    	-N eth1,total:有多块网卡时,指定要显示的网卡。
    	-l:显示系统负载情况。
    	-m:显示内存使用情况。
    	-g:显示页面使用情况。
    	-p:显示进程状态。
    	-s:显示交换分区使用情况。
    	-S:类似D/N。
    	-r:I/O请求情况。
    	-y:系统状态。
    	--ipc:显示ipc消息队列,信号等信息。
    	--socket:用来显示tcp udp端口状态。
    	-a:此为默认选项,等同于-cdngy。
    	-v:等同于 -pmgdsc -D total。
    	--output 文件:此选项也比较有用,可以把状态信息以csv的格式重定向到指定的文件中,以便日后查看。例:dstat --output /root/dstat.csv & 此时让程序默默的在后台运行并把结果输出到/root/dstat.csv文件中。    
    当然dstat还有很多更高级的用法,常用的基本这些选项,更高级的用法可以结合man文档。
    

     实例:

    如想监控swap,process,sockets,filesystem并显示监控的时间:
    [root@iZ23uulau1tZ ~]# dstat -tsp --socket --fs
    ----system---- ----swap--- ---procs--- ------sockets------ --filesystem-
      date/time   | used  free|run blk new|tot tcp udp raw frg|files  inodes
    26-07 09:23:48|   0     0 |  0   0 0.0|104   8   5   0   0|  704   6488
    26-07 09:23:49|   0     0 |  0   0   0|104   8   5   0   0|  704   6488
    26-07 09:23:50|   0     0 |  0   0   0|104   8   5   0   0|  704   6489
    26-07 09:23:51|   0     0 |  0   0   0|104   8   5   0   0|  704   6489
    26-07 09:23:52|   0     0 |  0   0   0|104   8   5   0   0|  704   6489
    26-07 09:23:53|   0     0 |  0   0   0|104   8   5   0   0|  704   6489
    
    若要将结果输出到文件可以加--output filename:
    [root@iZ23uulau1tZ ~]# dstat -tsp --socket --fs --output /tmp/ds.csv
    ----system---- ----swap--- ---procs--- ------sockets------ --filesystem-
      date/time   | used  free|run blk new|tot tcp udp raw frg|files  inodes
    26-07 09:25:31|   0     0 |  0   0 0.0|104   8   5   0   0|  736   6493
    26-07 09:25:32|   0     0 |  0   0   0|104   8   5   0   0|  736   6493
    26-07 09:25:33|   0     0 |  0   0   0|104   8   5   0   0|  736   6493
    26-07 09:25:34|   0     0 |  0   0   0|104   8   5   0   0|  736   6493
    26-07 09:25:35|   0     0 |  0   0   0|104   8   5   0   0|  736   6494
    26-07 09:25:36|   0     0 |  0   0   0|104   8   5   0   0|  736   6494
    
    这样生成的csv文件可以用excel打开,然后生成图表。
    通过dstat --list可以查看dstat能使用的所有参数,其中上面internal是dstat本身自带的一些监控参数,下面/usr/share/dstat中是dstat的插件,这些插件可以扩展dstat的功能,如可以监控电源(battery)、mysql等。
    下面这些插件并不是都可以直接使用的,有的还依赖其他包,如想监控mysql,必须要装python连接mysql的一些包。
    [root@iZ23uulau1tZ ~]# dstat --list
    internal:
            aio, cpu, cpu24, disk, disk24, disk24old, epoch, fs, int, int24, io, ipc, load, lock, mem, net, page, page24, proc, raw, socket, swap, swapold, sys, tcp, time, udp, unix, vm
    /usr/share/dstat:
            battery, battery-remain, cpufreq, dbus, disk-util, fan, freespace, gpfs, gpfs-ops, helloworld, innodb-buffer, innodb-io, innodb-ops, lustre, memcache-hits, mysql-io, mysql-keys, mysql5-cmds, mysql5-conn, mysql5-io, mysql5-keys,
            net-packets, nfs3, nfs3-ops, nfsd3, nfsd3-ops, ntp, postfix, power, proc-count, rpc, rpcd, sendmail, snooze, thermal, top-bio, top-cpu, top-cputime, top-cputime-avg, top-io, top-latency, top-latency-avg, top-mem, top-oom, utmp,
            vm-memctl, vmk-hba, vmk-int, vmk-nic, vz-cpu, vz-io, vz-ubc, wifi
    

    iostat 命令

    iostat:用于监视系统输入输出设备和CPU的使用情况。它的特点是汇报磁盘活动统计情况,同时也会汇报出CPU使用情况。同vmstat一样,iostat也有一个弱点,就是它不能对某个进程进行深入分析,仅对系统的整体情况进行分析。

    语法:iostat(选项)(参数)
    选项:
        -c:仅显示CPU使用情况;
        -d:仅显示设备利用率;
        -k:显示状态以千字节每秒为单位,而不使用块每秒;
        -m:显示状态以兆字节每秒为单位;
        -p:仅显示块设备和所有被使用的其他分区的状态;
        -t:显示每个报告产生时的时间;
        -V:显示版号并退出;
        -x:显示扩展状态。
    参数:
        间隔时间:每次报告的间隔时间(秒);
        次数:显示报告的次数。
    实例:用iostat -x /dev/sda1来观看磁盘I/O的详细情况:
    iostat -x /dev/sda1 
    Linux 2.6.18-164.el5xen (localhost.localdomain)
    2010年03月26日  
     
    avg-cpu:  %user   %nice %system %iowait 
    %steal   %idle  
                0.11    0.02    0.18    0.35   
    0.03    99.31  
     
    Device:         tps   Blk_read/s    Blk_wrtn/s  
    Blk_read   Blk_wrtn  
    sda1                0.02          0.08       
    0.00          2014               4 
    

     详细说明:第二行是系统信息和监测时间,第三行和第四行显示CPU使用情况(具体内容和mpstat命令相同)。这里主要关注后面I/O输出的信息,如下所示:

    Device	监测设备名称
    rrqm/s	每秒需要读取需求的数量
    wrqm/s	每秒需要写入需求的数量
    r/s 	每秒实际读取需求的数量
    w/s	每秒实际写入需求的数量
    rsec/s	每秒读取区段的数量
    wsec/s	每秒写入区段的数量
    rkB/s	每秒实际读取的大小,单位为KB
    wkB/s	每秒实际写入的大小,单位为KB
    avgrq-sz	需求的平均大小区段
    avgqu-sz	需求的平均队列长度
    await	等待I/O平均的时间(milliseconds)
    svctm	I/O需求完成的平均时间
    %util	被I/O需求消耗的CPU百分比
    

    free 命令

    free:显示当前系统未使用的和已使用的内存数目,还可以显示被内核使用的内存缓冲区。

    语法:free(选项)
    选项:
        -b:以Byte为单位显示内存使用情况;
        -k:以KB为单位显示内存使用情况;
        -m:以MB为单位显示内存使用情况;
        -o:不显示缓冲区调节列;
        -s<间隔秒数>:持续观察内存使用状况;
        -t:显示内存总和列;
        -V:显示版本信息。
    实例:
    free -m
                      total       used       free     shared    buffers     cached
    Mem:          2016       1973         42          0        163       1497
    -/+ buffers/cache:        312       1703
    Swap:         4094          0       4094
     
    第一部分Mem行解释:
        total:内存总数;
        used:已经使用的内存数;
        free:空闲的内存数;
        shared:当前已经废弃不用;
        buffers Buffer:缓存内存数;
        cached Page:缓存内存数。
    第二部分(-/+ buffers/cache)解释:
        (-buffers/cache) used内存数:第一部分Mem行中的 used – buffers – cached
        (+buffers/cache) free内存数: 第一部分Mem行中的 free + buffers + cached
    第三部分是指交换分区。
    

    lsof命令

    lsof:用于查看你进程开打的文件,打开文件的进程,进程打开的端口(TCP、UDP)。找回/恢复删除的文件。是十分方便的系统监视工具,因为lsof命令需要访问核心内存和各种文件,所以需要root用户执行。

    在linux环境下,任何事物都以文件的形式存在,通过文件不仅仅可以访问常规数据,还可以访问网络连接和硬件。所以如传输控制协议 (TCP) 和用户数据报协议 (UDP) 套接字等,系统在后台都为该应用程序分配了一个文件描述符,无论这个文件的本质如何,该文件描述符为应用程序与基础操作系统之间的交互提供了通用接口。因为应用程序打开文件的描述符列表提供了大量关于这个应用程序本身的信息,因此通过lsof工具能够查看这个列表对系统监测以及排错将是很有帮助的。

    语法:lsof(选项)
    选项:
        -a:列出打开文件存在的进程;
        -c<进程名>:列出指定进程所打开的文件;
        -g:列出GID号进程详情;
        -d<文件号>:列出占用该文件号的进程;
        +d<目录>:列出目录下被打开的文件;
        +D<目录>:递归列出目录下被打开的文件;
        -n<目录>:列出使用NFS的文件;
        -i<条件>:列出符合条件的进程。(4、6、协议、:端口、 @ip )
        -p<进程号>:列出指定进程号所打开的文件;
        -u:列出UID号进程详情;
        -h:显示帮助信息;
        -v:显示版本信息。    
    实例:
    lsof
    command     PID USER   FD      type             DEVICE     SIZE       NODE NAME
    init          1 root  cwd       DIR                8,2     4096          2 /
    init          1 root  rtd       DIR                8,2     4096          2 /
    init          1 root  txt       REG                8,2    43496    6121706 /sbin/init
    init          1 root  mem       REG                8,2   143600    7823908 /lib64/ld-2.5.so
    init          1 root  mem       REG                8,2  1722304    7823915 /lib64/libc-2.5.so
    init          1 root  mem       REG                8,2    23360    7823919 /lib64/libdl-2.5.so
    init          1 root  mem       REG                8,2    95464    7824116 /lib64/libselinux.so.1
    init          1 root  mem       REG                8,2   247496    7823947 /lib64/libsepol.so.1
    init          1 root   10u     FIFO               0,17                1233 /dev/initctl
    migration     2 root  cwd       DIR                8,2     4096          2 /
    migration     2 root  rtd       DIR                8,2     4096          2 /
    migration     2 root  txt   unknown                                        /proc/2/exe
    ksoftirqd     3 root  cwd       DIR                8,2     4096          2 /
    ksoftirqd     3 root  rtd       DIR                8,2     4096          2 /
    ksoftirqd     3 root  txt   unknown                                        /proc/3/exe
    migration     4 root  cwd       DIR                8,2     4096          2 /
    migration     4 root  rtd       DIR                8,2     4096          2 /
    migration     4 root  txt   unknown                                        /proc/4/exe
    ksoftirqd     5 root  cwd       DIR                8,2     4096          2 /
    ksoftirqd     5 root  rtd       DIR                8,2     4096          2 /
    ksoftirqd     5 root  txt   unknown                                        /proc/5/exe
    events/0      6 root  cwd       DIR                8,2     4096          2 /
    events/0      6 root  rtd       DIR                8,2     4096          2 /
    events/0      6 root  txt   unknown                                        /proc/6/exe
    events/1      7 root  cwd       DIR                8,2     4096          2 /
    

    lsof输出各列信息的意义如下:

    • COMMAND:进程的名称
    • PID:进程标识符
    • PPID:父进程标识符(需要指定-R参数)
    • USER:进程所有者
    • PGID:进程所属组
    • FD:文件描述符,应用程序通过文件描述符识别该文件。

    文件描述符列表:

    1. cwd:表示current work dirctory,即:应用程序的当前工作目录,这是该应用程序启动的目录,除非它本身对这个目录进行更改
    2. txt:该类型的文件是程序代码,如应用程序二进制文件本身或共享库,如上列表中显示的 /sbin/init 程序
    3. lnn:library references (AIX);
    4. er:FD information error (see NAME column);
    5. jld:jail directory (FreeBSD);
    6. ltx:shared library text (code and data);
    7. mxx :hex memory-mapped type number xx.
    8. m86:DOS Merge mapped file;
    9. mem:memory-mapped file;
    10. mmap:memory-mapped device;
    11. pd:parent directory;
    12. rtd:root directory;
    13. tr:kernel trace file (OpenBSD);
    14. v86  VP/ix mapped file;
    15. 0:表示标准输出
    16. 1:表示标准输入
    17. 2:表示标准错误

    一般在标准输出、标准错误、标准输入后还跟着文件状态模式:

    1. u:表示该文件被打开并处于读取/写入模式。
    2. r:表示该文件被打开并处于只读模式。
    3. w:表示该文件被打开并处于。
    4. 空格:表示该文件的状态模式为unknow,且没有锁定。
    5. -:表示该文件的状态模式为unknow,且被锁定。

    同时在文件状态模式后面,还跟着相关的锁:

    1. N:for a Solaris NFS lock of unknown type;
    2. r:for read lock on part of the file;
    3. R:for a read lock on the entire file;
    4. w:for a write lock on part of the file;(文件的部分写锁)
    5. W:for a write lock on the entire file;(整个文件的写锁)
    6. u:for a read and write lock of any length;
    7. U:for a lock of unknown type;
    8. x:for an SCO OpenServer Xenix lock on part      of the file;
    9. X:for an SCO OpenServer Xenix lock on the      entire file;
    10. space:if there is no lock.

    文件类型:

    1. DIR:表示目录。
    2. CHR:表示字符类型。
    3. BLK:块设备类型。
    4. UNIX: UNIX 域套接字。
    5. FIFO:先进先出 (FIFO) 队列。
    6. IPv4:网际协议 (IP) 套接字。
    7. DEVICE:指定磁盘的名称
    8. SIZE:文件的大小
    9. NODE:索引节点(文件在磁盘上的标识)
    10. NAME:打开文件的确切名称

    ifstat命令

    ifstat命令就像iostat/vmstat描述其它的系统状况一样,是一个统计网络接口活动状态的工具。ifstat工具系统中并不默认安装,需要自己下载源码包,重新编译安装,使用过程相对比较简单。

    下载:

    http://gael.roualland.free.fr/ifstat/  (官网)
    wget http://gael.roualland.free.fr/ifstat/ifstat-1.1.tar.gz
    

     编译安装:

    tar -zxvf ifstat-1.1.tar.gz
    cd ifstat-1.1
    ./configure            #默认会安装到/usr/local/bin/目录中
    make 
    make install

     注释:执行which ifstat输出/usr/local/bin/ifstat

    选项:

    -l 监测环路网络接口(lo)。缺省情况下,ifstat监测活动的所有非环路网络接口。经使用发现,加上-l参数能监测所有的网络接口的信息,而不是只监测 lo的接口信息,也就是说,加上-l参数比不加-l参数会多一个lo接口的状态信息。
    -a 监测能检测到的所有网络接口的状态信息。使用发现,比加上-l参数还多一个plip0的接口信息,搜索一下发现这是并口(网络设备中有一 个叫PLIP (Parallel Line Internet Protocol). 它提供了并口...)
    -z 隐藏流量是无的接口,例如那些接口虽然启动了但是未用的
    -i 指定要监测的接口,后面跟网络接口名
    -s 等于加-d snmp:[comm@][#]host[/nn]] 参数,通过SNMP查询一个远程主机
    -h 显示简短的帮助信息
    -n 关闭显示周期性出现的头部信息(也就是说,不加-n参数运行ifstat时最顶部会出现网络接口的名称,当一屏显示不下时,会再一次出现接口的名称,提示我们显示的流量信息具体是哪个网络接口的。加上-n参数把周期性的显示接口名称关闭,只显示一次)
    -t 在每一行的开头加一个时间 戳(能告诉我们具体的时间)
    -T 报告所有监测接口的全部带宽(最后一列有个total,显示所有的接口的in流量和所有接口的out流量,简单的把所有接口的in流量相加,out流量相 加)
    -w  用指定的列宽,而不是为了适应接口名称的长度而去自动放大列宽
    -W 如果内容比终端窗口的宽度还要宽就自动换行
    -S 在同一行保持状态更新(不滚动不换行)注:如果不喜欢屏幕滚动则此项非常方便,与bmon的显示方式类似
    -b 用kbits/s显示带宽而不是kbytes/s
    -q 安静模式,警告信息不出现
    -v 显示版本信息
    -d 指定一个驱动来收集状态信息

    实例:

    [root@flow_video]# ifstat -tT
      time           eth0                eth1                eth2                eth3               Total      
    HH:MM:ss   KB/s in  KB/s out   KB/s in  KB/s out   KB/s in  KB/s out   KB/s in  KB/s out   KB/s in  KB/s out
    16:53:04      0.84      0.62   1256.27   1173.05      0.12      0.18      0.00      0.00   1257.22   1173.86
    16:53:05      0.57      0.40      0.57      0.76      0.00      0.00      0.00      0.00      1.14      1.17
    16:53:06      1.58      0.71      0.42      0.78      0.00      0.00      0.00      0.00      2.01      1.48
    16:53:07      0.57      0.40      1.91      2.61      0.00      0.00      0.00      0.00      2.48      3.01
    16:53:08      0.73      0.40    924.02   1248.91      0.00      0.00      0.00      0.00    924.76   1249.31
    
  • 相关阅读:
    剑指Offer 19 正则表达式匹配
    剑指Offer 37 序列化二叉树
    剑指Offer 36 二叉搜索树与双向链表
    剑指Offer 35 复杂链表的复制
    剑指Offer 45 把数组排成最小的数
    华为有AI,这场转型战有点大
    NLP&深度学习:近期趋势概述
    2018年度10大新兴技术:人工智能、量子计算、增强现实等
    外媒评李开复的《AI·未来》:四大浪潮正在席卷全球
    商汤科技汤晓鸥:其实不存在AI行业,唯一存在的是“AI+“行业
  • 原文地址:https://www.cnblogs.com/smile1/p/11968080.html
Copyright © 2011-2022 走看看