zoukankan      html  css  js  c++  java
  • Linux系统性能监控工具nmon

    一、简介

    nmon 工具可以帮助在一个屏幕上显示所有重要的性能优化信息,并动态地对其进行更新。这个高效的工具可以工作于任何哑屏幕、telnet 会话、甚至拨号线路。另外,它并不会消耗大量的 CPU 周期,通常低于百分之二。在更新的计算机上,其 CPU 使用率将低于百分之一。使用哑屏幕,在屏幕上对数据进行显示,并且每隔两秒钟对其进行更新。然而,您可以很容易地将这个时间间隔更改为更长或更短的时间段。如果您拉伸窗口,并在X Windows、VNC、PuTTY 或类似的窗口中显示这些数据,nmon 工具可以同时输出大量的信息。 nmon 工具还可以将相同的数据捕获到一个文本文件,便于以后对报告进行分析和绘制图形,输出文件采用电子表格的格式。

    二、下载

    下载地址:http://nmon.sourceforge.net/pmwiki.php?n=Site.Download
    下载的文件名为:nmon16d_x86.tar.gz(下载时间不同,版本号可能不同)
    将该文件下载到本地,解压,解压后文件夹中的一部分内容如下图所示:

    三、使用
    根据自己的linux系统版本在解压后的文件夹里选择合适的文件,一般用nmon_linux_x86_64即可。然后使用ftp上传到linux服务器的/usr/local/bin目录并增加可执行权限。
    修改权限:chmod 755 nmon_linux_x86_64
    在任何目录下输入nmon_linux_x86_64都可以显示cpu等信息了,
    (注:如果觉得nmon_linux_x86_64这个命令太长,可以在/usr/local/bin目录下将该文件换名mv nmon_linux_x86_64 nmon)
    此时在任何目录下输入nmon,如下面截图所示:

    四、生成nmon报告

    #nmon -s10 -c30 -f -m /home/chen

    参数解释:
    -s10 每 10 秒采集一次数据;
    -c30 采集 30 次,采集总时长:30*10=300秒;
    -f 生成的报告文件名中包含文件创建的时间;
    -m 生成的报告文件的存放目录;
    生成的文件名如下: XXXXX_180816_1059.nmon ,"XXXXX" 是机器的主机名。

    可以通过nmon -h查看有关nmon的更多使用方法。

    五、用nmon_analyser工具进行查看报告

    将生成的报告传到本地,用nmon_analyser工具进行查看
    1、将/home/chen目录下的XXXXX_180816_1059.nmon文件ftp到本地文件夹
    2、下载nmon_analyser工具
    地址:https://www.ibm.com/developerworks/community/wikis/home?lang=en#!/wiki/Power%20Systems/page/nmon_analyser
    需要下载的文件名:nmon_analyser_v54.zip(注:下载时间不同,文件名可能会不同)
    下载到本地解压后,打开.xlsm文件,点击‘Analyze nmon data’,此时可能会提示‘宏不可用’,点击‘启用宏’;
    再次点击‘Analyze nmon data’,选择刚才ftp到本地的.nmon文件,显示如下图所示:

    六、nmon结果文件分析
    nmon文件解析出来之后生成的excel表格,有几十个sheet;下面就这些sheet所列指标的含义进行分析。

    常用指标分析
    监控操作系统,最关注的几个指标分别是CPU、内存、磁盘IO、网络等。下面对几张关键图表进行分析。

    a.CPU_ALL:所有CPU概述,显示监控系统所有CPU的平均占用情况,包含User/Sys/Wait/Idle状态
    1、User%,用户模式下执行的程序所使用的CPU百分比
    2、Sys%,内核模式下执行的程序所使用的CPU百分比
    3、Wait%,等待 IO 所花的时间百分比
    4、Idel%,CPU的空闲时间百分比,此值和User%,Sys%,Wait%之和等于1
    5、CPU%,CPU总体占用情况,这个值通常等于User%+Sys%+Wait%
    6、CPUs,CPU核数,即操作系统是多少C的

    b. DISK_SUM:总体disk读、写以及I/O操作
    1、Disk Read KB/s ,每个磁盘执行采样数据(磁盘设备的读速率)
    2、Disk Write KB/s ,每个磁盘执行采样数据(磁盘设备的写速率)
    3、IO/sec,每秒钟输出到物理磁盘的传输次数

    c. DISKBUSY:每个hdisk设备平均占用情况
    单位为%(百分比)

    d. MEM:内存使用情况描述,包括物理内存和虚拟内存
    1、memtotal,物理内存总大小
    2、swaptotal,虚拟内存(即交换空间)的总大小
    3、memfree,剩余物理内存大小
    4、swapfree,剩余虚拟内存大小
    5、cached,已占用的文件系统缓存大小,由物理内存分配
    6、buffers,文件系统缓冲区大小
    7、swapcached,虚拟内存中已分配出来的内存大小
    8、inactive,最近不常使用的内存大小

    e. NET:系统中每个网络适配器的数据传输速率(千字节/秒)
    1、Total-Read,网络适配器每秒接收的数据包总大小,单位是KB/sec
    2、Total-Write (-ve),网络适配器每秒发送的数据包总大小,单位是KB/sec
    3、eth0-total,网络适配器每秒接收和发送的数据包总大小,单位是KB/sec

    f.Sheet名称
    1、SYS_SUMM:系统汇总,蓝线为cpu占有率变化情况,粉线为磁盘IO的变化情况;
    2、AAA:关于操作系统以及nmon本身的一些信息;
    3、BBBP:vmtune, schedtune, emstat和lsattr命令的输出信息;
    4、CPUnn:显示执行之间内CPU占用情况,其中包含user%、sys%、wait%和idle%;
    5、CPU_SUMM:每一个CPU在执行时间内的占用情况,其中包含user%、sys%、wait%和idle%;
    6、DISKBSIZE:执行时间内每个hdisk的传输块大小;
    7、DISKREAD:每个hdisk的平均读情况;
    8、DISKWRITE:每个hdisk的平均写情况;
    9、DISKXFER:每个hdisk的I/O每秒操作;
    10、JFSFILE:本sheet显示对于每一个文件系统中,在每个间隔区间正在被使用的空间百分比
    11、NETPACKET:本sheet统计每个适配器网络读写包的数量
    12、PROC:本sheet包含nmon内核内部的统计信息。其中RunQueue和Swap-in域是使用的平均时间间隔,其他项的单位是比率/秒
    13、ZZZZ:本sheet自动转换所有nmon的时间戳为现在真实的时间,方便更容易的分析

  • 相关阅读:
    CSUOJ 1081 集训队分组
    HDU 1865 More is Better
    HDU 1325 Is It A Tree?
    HDU 1272 小希的迷宫
    CSUOJ 1217 奇数个的那个数
    CSUOJ 1010 Water Drinking
    CSUOJ 1162 病毒
    CodeForces 295B
    CodeForces 20C
    SPOJ MULTQ3
  • 原文地址:https://www.cnblogs.com/chen/p/9485983.html
Copyright © 2011-2022 走看看