近期在测试JefLogTail,由于JefLogTail使用的是轮询的方式来监听文件夹,所以对cpu的消耗可能会高一些,所以在测试的时候着重关注CPU,Linux下查看CPU信息一般采用top命令来实时观察,但是这种对于只是通过观察数据的变化来评估cpu的实时情况显然不太科学。如果想要通过图标的形式来表现则需要借助一些外部工具,今天就来讲解一下nmon工具的使用。
官方下载地址:nmon.sourceforge.net/pmwiki.php?…需要根据自己的Linux主机版本来下载对应的版本,笔者这里下载的是nmon16m_helpsystems.tar.gz,下载完成后在linux主机上解压后,会出现很多版本,选择对应的版本运行即可。 笔者的主机配置为:
Linux version 3.10.0-514.el7.x86_64 (mockbuild@x86-039.build.eng.bos.redhat.com) (gcc version 4.8.5 20150623 (Red Hat 4.8.5-11) (GCC) ) #1 SMP Wed Oct 19 11:24:13 EDT 2016
nmon对应笔者主机的版本为:
nmon_x86_64_rhel7
执行./nmon_x86_64_rhel7,如果成功则会展示如下界面:
使用示例:
根据提示输入C,展示的为CPU的各项指标
输入M,展示的为内存的各项指标
输入d,展示的为磁盘的各项指标等等
nmon不仅可以实时监听,还提供命令监听,并写入到文件,最后通过excel来展示图形化的界面。
使用如下命令可监听系统的各项指标。并汇总文件中。
./nmon_x86_64_rhel7 -ft -s 1000 -c 60 -m /test_path
命令参数说明:
-f 监控结果以文件形式输出,默认机器名+日期.nmon格式 (YYYYMMDD_HHMM.nmon)
-F 指定输出的文件名,比如test.nmon
-s 指的是采样的频率,单位为毫秒
-c 指的是采样的次数,即以上面的采样频率采集多少次
-m 指定生成的文件目录
上述命令的意思为:每1秒钟采集一次,共采集60秒,并且将生成的文件保存到根目录下的test_path文件夹下。执行完该命令后,在/test_path下就会生成一个名为:localhost_230426_1359.nmon的文件。
文件解析需要下载官方的解析工具,这个工具不需要安装,只是一个excel宏命令文件,所以可以放心下载。 地址:nmon.sourceforge.net/pmwiki.php?…
下载完成后,解压打开nmon analyser v66.xlsm文件,点击Analyze nmon data按钮,如果此时报错,提示类似“无法运行xxxx宏可能是因为该宏在此工作簿中不可用,或者所有宏都被禁用”,需要配置一下excel宏,配置路径:文件=》选项=》信任中心=》信任中心设置=》宏设置,勾选启用所有宏。设置完毕重启即可。之后按照提示傻瓜式操作。
解析之后的图形化excel
# 启动指令 monitor_system_start () { # 频率默认为1000ms采集一次 frequency=1000 # 采样次数默认为60次 count=60 # 默认保存路径 save_path='/home/xxx/tools/nmonData/' if [ "$1" != "" ]; then frequency=$1 fi if [ "$2" != "" ]; then count=$2 fi if [ "$3" != "" ]; then save_path=$3 fi commond='/home/xxx/tools/nmonData/tools/nmon/nmon_x86_64_rhel7 -ft -s '$frequency' -c '$count' -m '$save_path $commond echo "start success" } # 强制停止指令 monitor_system_stop () { commond="ps -ef | grep nmon_x86_64_rhel7 | grep -nv 'grep' | awk -F ' *' '{print $"2"}'" pid=`eval $commond` echo $pid kill -9 $pid echo "stop success PID="$pid } command_array=("monsysstop" "monsysstart") if [ $# -lt 1 ]; then echo "请明确指令:" length=${#command_array[@]} for ((i=0;i<$length; i++)); do echo ${command_array[$i]} done exit else if [[ $1 == 'monsysstart' || $1 == '-monsysstart' || $1 == "MONSYSSTART" ]] then monitor_system_start $2 $3 $4 elif [[ $1 == 'monsysstop' || $1 == '-monsysstop' || $1 == "MONSYSSTOP" ]] then monitor_system_stop
使用方式:
1、默认启动
sh xxx.sh monsysstart
2、自定义参数启动
sh xxx.sh monsysstart 1000 60 /test_path
3、强行停止(正常执行完指定的采集次数后会自动停止,一般不需要强行停止):
sh xxx.sh monsysstop
到此这篇关于Linxu下性能指标采集工具之nmon工具的使用的文章就介绍到这了,更多相关Linxu nmon工具的使用内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!