zoukankan      html  css  js  c++  java
  • 【Linux资源管理】一款优秀的linux监控工具——nmon

    (一)nmon工具概述

    nmon是以一个用来做linux服务器监控的工具,通过nmon,可以实现对以下参数的监控:

      --CPU使用率

      --内存、交换空间使用率

      --网络使用情况

      --磁盘I/O,读写速度

      --网络I/O速度,传输和读写速度

      --顶级进程,查看哪些应用程序占用的CPU较多

      --网络文件系统NFS

      --文件系统使用情况(类似df -h)

    等。。。

    (二)nmon工具的部署

    STEP1.下载安装包:http://nmon.sourceforge.net/pmwiki.php?n=Site.Download。

    注释:这里需要根据自己的linux类型及版本选择合适的安装包,我的redhat 6.6 linux信息为

    lsb_release: Distributor ID : RedHatEnterpriseServer
    lsb_release: Description    : Red Hat Enterprise Linux Server release 6.6 (Santiago)

    ,经测试,可以使用nmon16e_mpginc.tar.gz下面的“nmon_x86_64_rhel6”。

    STEP2.解压安装包

    [root@redhat6 ~]# mkdir /opt/nmon/nmon16e
    
    [root@redhat6 nmon16e]# pwd
    /opt/nmon/nmon16e
    [root@redhat6 nmon16e]# tar -xzvf nmon16e_mpginc.tar.gz
    ...
    nmon_x86_64_opensuse12
    nmon_x86_64_rhel6
    nmon_x86_64_rhel7
    ...
    
    [root@redhat6 nmon16e]# ll
    total 12540
    -rw-r--r--. 1 root root 3456878 Aug 13 10:16 nmon16e_mpginc.tar.gz
    -rw-r--r--. 1 root root  383072 Apr 14  2016 nmon_arm_ubuntu15
    -rwxr-x---. 1 root root  342054 Apr 20  2016 nmon_power_32_rhel6
    -rwxr-x---. 1 root root  353612 Apr 20  2016 nmon_power_32_sles11
    -rwxr-x---. 1 root root  460578 Apr 20  2016 nmon_power_64_kvm2
    -rwxr-x---. 1 root root  464824 Apr 20  2016 nmon_power_64le_fedora22
    -rwxr-x---. 1 root root  464824 Apr 20  2016 nmon_power_64le_rhel6
    -rwxr-x---. 1 root root  464824 Apr 20  2016 nmon_power_64le_rhel7
    -rwxr-x---. 1 root root  540615 Apr 20  2016 nmon_power_64le_ubuntu14
    -rwxr-x---. 1 root root  561504 Apr 20  2016 nmon_power_64le_ubuntu15
    -rwxr-x---. 1 root root  551472 Apr 20  2016 nmon_power_64le_ubuntu16
    -rwxr-x---. 1 root root  405725 Apr 20  2016 nmon_power_64_rhel6
    -rwxr-x---. 1 root root  460578 Apr 20  2016 nmon_power_64_rhel7
    -rwxr-x---. 1 root root  418328 Apr 20  2016 nmon_power_64_sles11
    -rwxr-----. 1 root root  347506 Apr 14  2016 nmon_x86_64_centos6
    -rwxr-----. 1 root root  402146 Apr 14  2016 nmon_x86_64_centos7
    -rwxr-----. 1 root root  345503 Apr 14  2016 nmon_x86_64_opensuse11
    -rwxr-----. 1 root root  394628 Apr 14  2016 nmon_x86_64_opensuse12
    -rwxr-----. 1 root root  347506 Apr 14  2016 nmon_x86_64_rhel6
    -rwxr-----. 1 root root  402146 Apr 14  2016 nmon_x86_64_rhel7
    -rwxr-----. 1 root root  345503 Apr 14  2016 nmon_x86_64_sles11
    -rwxr-----. 1 root root  394628 Apr 14  2016 nmon_x86_64_sles12
    -rwxr-----. 1 root root  481776 Apr 14  2016 nmon_x86_64_ubuntu15

    STEP3.找到与自己操作系统对应的文件,直接执行,即可进入nmon工具

    [root@redhat6 nmom6e]# ./nmon_power_64_rhel6

    (三)nmon实时监控

    可以使用nmon进行实时监控,命令主要包括三种类型:

    • 帮助命令
    • 监控参数命令
    • 监控辅助命令

    (3.1)帮助命令

    帮助命令为“H”,通过H命令可以了解到nmon的命令及作用

     (3.2)监控命令

     命令 英文解释 作用
     c | C

    c = CPU Util   ;      

    C = wide view   

    用于监控CPU的使用情况。针对每核CPU的四种状态进行统计:

    User%:用户使用CPU百分比                 Sys% :系统使用CPU百分比

    Wait%:CPU(非空闲)等待百分比       Idle%:空闲CPU百分比

     m | L

    m = memory & swap  ;   

    L = Large(Huge) Page

    用于监控内存及交换空间的使用情况,还可以使用“L”命令查看Large(Huge) Page的使用情况
     n n = network

     监控每块网卡的I/O情况,主要监控

      --每秒接受/发送的流量

      --进出网卡的package的数量

      --进出流量(默认是2秒)

      --每秒接受/发送的流量的峰值

     d

    d = Disk I/O Graphs         

    D = Status

    监控磁盘I/O情况,通过这个命令,可以看到磁盘的繁忙程度,读写速度,用“D”可以看到更细节的磁盘I/O信息

    注:如果磁盘sda分区成为:sda1、sda2,那么会显示三个磁盘(sda、sda1、sda2)的信息。

     k k = kernel status & loadavg

    监控内核状态及负载,通过这个参数,可以了解到CPU具体消耗在哪些地方

    --全部CPU的使用负载,CPU具体耗费在哪些地方也有所描述,不同于前面c或C对单个CPU统计

    --全部CPU的平均负载(1min、5min、15min)

     M M = MHz by thread & CPU CPU的时钟震荡频率 
     t

    t = Top Process,可选参数:

      --1:Priority/Nice/STate 

      --3:CPU

      --4:RAM

      --5:I/O

    顶级进程,可通过一下方式排序

    --1:基础方式,个人感觉不实用

    --3:按CPU消耗排序

    --4:按内存消耗排序

    --5:按I/O消耗排序

     g g = User Defined Disk Groups  用户定义的磁盘组信息
     r r = Resources OS & Proc

    操作系统资源信息,如:

    --CPU型号、CPU频率、每颗CPU的物理内核、超线程、虚拟CPU数量

    --操作系统版本:linux版本、redhat版本

     l l = long term CPU averages 长期的CPU负载监控。类似于windows任务管理器提供的CPU监控功能 
     V v = Virtual Memory 虚拟内存使用情况 
     N N = NFS  NFS网络文件系统I/O统计
     o o = Disk %Busy Map 通过MAP图,记录了哪些磁盘在使用,哪些磁盘未使用  
     j j = Filesystem Usage 文件系统的使用情况,类似于df -h
     u u = Top Process with command line Hit u twice to update 顶级进程,带有两次去更新数据操作
     G G = with -g switches Disk Graphs to disk groups only  不清楚具体作用,略

    (3.3) 辅助监控命令

    命令 英文解释 作用
     “+” (shift+“+”)  “+” = double the screen refresh time  屏幕刷新频率改为2倍
     “-”  “ - ” = half the screen refresh time   屏幕刷新频率改为一半
     “.” “.” = Display only busy disk & CPU   标出处于繁忙状态的CPU 
     0  0 = reset peak marks(">") to zero  将峰值重新设置为0 
     space space refresh screen now   空格键手动刷新屏幕 
     b  black & white mode  颜色显示为黑白模式 
     q q = Quit    退出 

    (四)nmon数据非实时分析

    除了实时分析外,还可以对数据进行收集,然后使用nmonchart、nmon_analyser工具将收集的数据进行绘图、展现。

    nmon收集数据命令如下:

    [root@redhat6 nmom6e]# ./nmon_x86_64_rhel6 -s1 -c300 -f -m /opt/nmon/nmon16e/file

    参数说明:
    -s1      : 每隔n秒抽样一次,这里为1s;
    -c300  : 采样次数,这里为300次;
    -f         : 按照标准格式输出文件名称:<hostname>_YYMMDD_HHMM.nmon
    -m       : 文件输出路径

    最终会生成一个nmon文件,在得到nmon文件后,可以使用nmonchart或者是nmon analyser来绘制图形。

    接下来介绍一下nmonchart与nmon_analyser的用法。

    (4.1)使用nmonchart生成图形

    如上所述,nmon收集数据后,会形成一个*.nmon文件,我们可以使用nmonchart来生成html的服务器性能报表,

     nmonchart下载地址:http://nmon.sourceforge.net/pmwiki.php?n=Site.Nmonchart

     使用语法:nmonchart <nmon-file> <output-file>.html

    例子:使用nmonchart将redhat6_180814_1014.nmon转换为html图形报表

    [root@redhat6 ~]/opt/nmon/nmon16e/nmonchart/nmonchart  /opt/nmon/nmon16e/file/redhat6_180814_1014.nmon  /opt/nmon/nmon16e/file/redhat6_180814_1014.html 

     执行提示异常:-bash: ./nmonchart: /usr/bin/ksh: bad interpreter: No such file or directory

    解决办法:

    nmonchart需要使用ksh,这里提示没有在"/usr/bin/ksh"没有找到ksh,先确定系统有没有安装ksh。我的系统的redhat6.5,是安装了ksh的

    [root@redhat6 ~]# which ksh
    /bin/ksh

    既然有ksh,就不用安装了,直接修改nmonchart的shell即可,编辑nmonchart文件  vi /home/nmon/nmonchart31/nmonchart ,修改第一行#!/usr/bin/ksh 为#!/bin/ksh。然后再执行转换命令就好了

    按理说打开html文档,可以看到官方提供的这样的图

     

    但是我打开之后,却是这样的。。。上面的按钮无法点开看到图像,以为是浏览器的原因,试了chrome、firefox、ie都不好使。一时没法搞定,暂放一下,再想想是哪里出了问题

    (4.2)使用nmon_analyser生成图形

     nmon analyser是一个excel工具,下载地址为:https://www.ibm.com/developerworks/community/wikis/home?lang=en#!/wiki/Power+Systems/page/nmon_analyser 。

    下载解压之后,有2个文件,word文档是analyser的用户指南,对analyser工具的使用介绍得非常详细,excel就是我们用来做数据分析的工具了。

    初次使用时,一般会提示“宏已被禁用”,我们需要启用宏

    接着点击“Analyze nmon data”按钮,将需要分析的*.nmon文件加载到excel中,分析完成后,会生成一个新的excel,里面记录了服务器的各项参数信息,我们简单的看几个图形:

    图1:SYS_SUMM。这个图对一段时间内服务器的CPU、I/O进行了统计

     图2:DISK_SUMM。这个图反映了磁盘的读写速度以及I/O请求的数量

    图3 :CPU_ALL。反馈了CPU的负载情况

    图4:CPU_SUMM。反馈了在真个时间段内每核CPU的负载情况

     

    图5 图6 NET。反馈了整体网络I/O情况以及每个网卡的I/O的情况

    图7:CPU001:反馈了第1核CPU在监控时间段内的负载情况(这台服务器有48核心,这里只列出1核)

    (五)nmon工具使用心得

    nmon工具非常小巧,却又非常的强大,nmon大小不足1MB,却能够监控10多项重要参数,相对于其它的工具,例如iostat、top等,nmon显示的信息更多,对用户也更友好,作为一个linux的初级使用者,也能理解其中的大部分信息。

    由于linux和操作系统基础较差,目前我个人只能理解一部分参数,后续还需加强学习。此外nmonchart也未成功draw出图形,也需寻找原因。

  • 相关阅读:
    qunar面试题及一位大牛的解答
    深入理解js里面的this
    用js实现的一个可拖动标签的例子
    Linux启动详细过程(开机启动顺序)
    linux下用top命令查看cpu利用率超过100%
    linux内核内存管理(zone_dma zone_normal zone_highmem)
    用户线程与内核线程如何映射?
    Linux用户空间与内核地址空间
    linux超级块和inode 详解 和 df 、du 命令详解与环境变量
    内核空间、进程和线程等概念
  • 原文地址:https://www.cnblogs.com/lijiaman/p/9466614.html
Copyright © 2011-2022 走看看