资源监控_自己编写一个nmon

2024-03-26 02:58
文章标签 编写 资源 监控 nmon

本文主要是介绍资源监控_自己编写一个nmon,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


          监控资源是测试工作中非常常见的事情,悲催的是每年都会临到用时又折腾一下。因为操作系统不断的在改变,监控的工具也在不断的随着改变。要么去搞搞rpc,然后用loadrunner连接上系统来监控,要么就搞个类似nmon一类的工具来监控,生成漂亮的图表。等到多年以后,发现其实真正需要监控的参数就那么几个,cpu、mem、disk和net,再多了未必用得到,还消耗资源,比如监控磁盘读写队列,有用吗?没用吗?要是disk增长很迅速,cpu占用大,大多数人都会意识到磁盘读写的很厉害了,所以监控磁盘读写队列未必那么有用,够用就好了。使用nmon后,觉得挺省心的,不过就有个不爽的地方,对系统是监控了一大堆,但是对进程没监控。

 

基于上面的两个需求,一是监控足够少的参数,二是对进程要有监控,所以搞了一个我的nmon。说起来很简单,就是以脚本生成一大堆的csv,然后使用一个vba脚本汇总生成excel文件,同时生成图表。

 

好了,来介绍一下mynmon吧,在ubuntu下测试通过,vba脚本在office2007下测试通过。不过我还是没太足的信心,欢迎大家帮忙测试一下。

 

脚本:mynmon.sh:

 

脚本包括两部分:

一部分是对系统的CPU,NET,MEM,DISK进行的监控

另一部分是对参数中的进程列表进行的监控,细节好像也没啥好说的了,大家自己看吧

 

另:调试信息的是顶头两个#的行,需要开启调试信息的时候,就直接vi文件,使用

:%s/^##//  替换掉,要关闭调试信息,就把顶头的echo加上两个#

#Two parts: system & process

#usage:./mynmon.sh interval "processname1 processname2 processname3..."

 

SLEEP_TIME=$1

P_LIST=$2

 

OUT1="SYS.CSV"

OUT2TMP=".CSV"

OUT2=""

S1=""

STMP1=""

S2=""

STMP2=""

PID=""

 

rm *.CSV

 

#system resource

S1="NETIN(k),NETOUT(k),DISK USED(k),CPU 1MIN LOAD,MEM FREE(k)\n"

printf "$S1">$OUT1

 

 

while :

do

 

#1.network

STMP1=`/sbin/ifconfig eth0|sed -n "8"p|awk '{print $2}'|awk -F: '{print $2}'`

##echo "NET IN:"$STMP1

STMP1=`echo $STMP1"/1000"|bc`

S1="$STMP1,"

STMP1=`/sbin/ifconfig eth0|sed -n "8"p|awk '{print $6}'|awk -F: '{print $2}'`

##echo "NET OUT:"$STMP1

STMP1=`echo "$STMP1/1000"|bc`

S1="$S1$STMP1,"

 

#2.disk

STMP1=`df --total|grep total|awk '{print $3}'`

##echo "DISK:"$STMP1

S1="$S1$STMP1,"

 

#3.cpu one minute load

 

STMP1=`uptime|awk -F, '{print $4}'|awk '{print $3}'`

##echo "CPU:"$STMP1

S1="$S1$STMP1,"

 

#4.mem free

 

STMP1=`vmstat 1 1|sed -n '3p'|awk '{print $4}'`

##echo "MEM:"$STMP1

S1="$S1$STMP1\n"

 

##echo "$S1"

printf "$S1">>$OUT1

 

 

#process resource

for p in $P_LIST

do

   OUT2="$p""_""$OUT2TMP"

##echo "PROCESS:$p OUT2:$OUT2"

   if [ -f "$OUT2" ]

   then

      :

   else

      printf "CPU LOAD,MEM(m)\n">"$OUT2"

   fi

 

   #1.get pid

   PID=`ps -ef|grep $p|grep -v grep|grep -v mynmon|awk '{print $2}'|sed -n '1p'`

 

   if [ "-$PID" = "-" ]

   then

   {

      echo "The process <$p> does not exist."

      echo "The process <$p> does not exist." >$OUT2

   }

   else

   {

      #1.CPU

      STMP2=`ps -p $PID -o pcpu |grep -v CPU | awk '{print $1}'`

##echo "PROCESS $p CPU:"$STMP2

      S2="$STMP2,"

 

      #2.MEM

      STMP2=`ps -o rss -p $PID|grep -v RSS`

      STMP2=`echo "$STMP2/1000"|bc`

##echo "PROCESS $p MEM:$STMP2"

      S2="$S2$STMP2"

 

##echo "$S2"

      printf "$S2\n">>"$OUT2"

   }

   fi

 

done

 

   sleep $SLEEP_TIME

done

 

启动方式:

nohup ./mynmon.sh 120 “key1 key2 key3 key4”

 

 

处理脚本:mynmonlog.xls:


使用方法:


 


001.jpg

 

算法:

1.新建excel文件;

2.寻找需要处理目录下的所有csv文件,根据<目录名_文件名>,给excel添加sheet,顺带删除了缺省的sheet1,sheet2和sheet3;

3.打开csv文件,把内容粘贴进sheet中;

4.SYS文件单独生成:(netin,netout和net),cpu,mem free和chart;

5.WIN文件单独生成:(netin,netout和net),cpu,mem free和chart;

6.其他文件生成cpu和mem free的chart;

7.保存为配置的结果文件

 

Private Declare Function OpenClipboard Lib "user32" (ByVal Hwnd As Long) As Long

Private Declare Function CloseClipboard Lib "user32" () As Long

Private Declare Function EmptyClipboard Lib "user32" () As Long

 

Sub EraseClipboard()

    If (OpenClipboard(0&)) Then

        Call EmptyClipboard

        Call CloseClipboard

    End If

End Sub

 

 

Sub Main()

 

Dim objExcel As Excel.Application

Dim Excelbook As Workbook

Dim Excelsheet As Worksheet

 

Dim strXls

 

Dim objExcel1 As Excel.Application

Dim Csvbook As Workbook

Dim Csvsheet As Worksheet

 

Dim fso, f, f1, fc, myFile

Dim strDoFolder, strSubFolder, strDoFile

 

Dim lngCnt, lngI

Dim g As ChartObject

 

Dim dt1, dt2

dt1 = Now

 

strDoFolder = ThisWorkbook.Path & "\" & ThisWorkbook.ActiveSheet.Cells(3, 2).Value & "\"

strXls = ThisWorkbook.Path & "\" & ThisWorkbook.ActiveSheet.Cells(4, 2).Value

'Debug.Print strDoFolder

'Debug.Print strXls

 

Set objExcel = CreateObject("Excel.Application")

Set Excelbook = objExcel.Workbooks.Add    '新建EXCEL文件

objExcel.Visible = True

 

Set fso = CreateObject("Scripting.FileSystemObject")

If fso.FileExists(strXls) Then

    fso.DeleteFile strXls, True

End If

 

Set f = fso.GetFolder(strDoFolder)

Set fc = f.SubFolders

For Each f1 In fc

   strSubFolder = strDoFolder & f1.Name

   If f1.Files.Count > 0 Then

      For Each myFile In f1.Files

         strDoFile = strSubFolder & "\" & myFile.Name

         'DEBUG.PRINT UCase(fso.GetExtensionName(strDoFile)) & vbCrLf & strDoFile

        

         If UCase(fso.GetExtensionName(strDoFile)) = "CSV" Then

            Set Excelsheet = Excelbook.Worksheets.Add  '添加工作页

            Excelsheet.Name = Left(f1.Name & "_" & fso.GetBaseName(strDoFile), 30)

 

            Set objExcel1 = CreateObject("Excel.Application")

            Set Csvbook = objExcel1.Workbooks.Open(strDoFile) '打开CSV文件

            Set Csvsheet = Csvbook.Worksheets(1) '取CSV文件的sheet

       

            objExcel1.Visible = True

           

            Csvsheet.Activate

            Csvsheet.Cells.Select

            objExcel1.Selection.Copy

       

            Excelsheet.Activate

            Excelsheet.Cells(1, 1).Select

            Excelsheet.Paste

           

            '对于不同的SYS,WIN,其他进程的监控结果不同的处理

            If UCase(Left(fso.GetBaseName(strDoFile), 3)) = "SYS" Then

              

                lngCnt = Excelsheet.UsedRange.Rows.Count

                Excelsheet.Cells(1, 6).Value = "NETIN(K)"

                Excelsheet.Cells(1, 7).Value = "NETOUT(K)"

                Excelsheet.Cells(1, 8).Value = "NET(K)"

               

                For lngI = 2 To lngCnt - 1

                    Excelsheet.Cells(lngI, 6).Value = Excelsheet.Cells(lngI + 1, 1).Value - Excelsheet.Cells(lngI, 1).Value

                    Excelsheet.Cells(lngI, 7).Value = Excelsheet.Cells(lngI + 1, 2).Value - Excelsheet.Cells(lngI, 2).Value

                    Excelsheet.Cells(lngI, 8).Value = Excelsheet.Cells(lngI, 6).Value + Excelsheet.Cells(lngI, 7).Value

                Next

               

                Set g = Excelsheet.ChartObjects.Add(400, 10, 400, 250)

                With g.Chart

                     .ChartType = xlLine

                    .SetSourceData Source:=Excelsheet.Range("$F:$H")

                End With

               

                Set g = Excelsheet.ChartObjects.Add(450, 60, 400, 250)

                With g.Chart

                     .ChartType = xlLine

                    .SetSourceData Source:=Excelsheet.Range("$D:$D")

                End With

                   

                Set g = Excelsheet.ChartObjects.Add(500, 110, 400, 250)

                With g.Chart

                     .ChartType = xlLine

                    .SetSourceData Source:=Excelsheet.Range("$E:$E")

                End With

               

            ElseIf UCase(Left(fso.GetBaseName(strDoFile), 3)) = "WIN" Then

 

                Set g = Excelsheet.ChartObjects.Add(450, 60, 400, 250)

                With g.Chart

                     .ChartType = xlLine

                    .SetSourceData Source:=Excelsheet.Range("$B:$C")

                End With

                   

                Set g = Excelsheet.ChartObjects.Add(500, 110, 400, 250)

                With g.Chart

                     .ChartType = xlLine

                    .SetSourceData Source:=Excelsheet.Range("$G:$G")

                End With

 

            Else

               

                Set g = Excelsheet.ChartObjects.Add(450, 60, 400, 250)

                With g.Chart

                     .ChartType = xlLine

                    .SetSourceData Source:=Excelsheet.Range("$A:$A")

                End With

                   

                Set g = Excelsheet.ChartObjects.Add(500, 110, 400, 250)

                With g.Chart

                     .ChartType = xlLine

                    .SetSourceData Source:=Excelsheet.Range("$B:$B")

                End With

           

            End If

           

            '清空剪切板

            Call EraseClipboard

           

            Csvbook.Close SaveChanges:=False

       

            Set Csvsheet = Nothing

            Set Csvbook = Nothing

            Set objExcel1 = Nothing

 

         Else

        

         End If

      Next

   End If

 

Next

 

Excelbook.Worksheets("Sheet1").Delete

Excelbook.Worksheets("Sheet2").Delete

Excelbook.Worksheets("Sheet3").Delete

Excelbook.SaveAs strXls

Excelbook.Close

  

Set Excelsheet = Nothing

Set Excelbook = Nothing

Set objExcel = Nothing

 

Set fso = Nothing

Set f = Nothing

Set fc = Nothing

 

dt2 = Now

MsgBox "执行完成,总共用时:" & DateDiff("s", dt1, dt2) & "秒"

 

 

End Sub

 

 

上面的内容牵涉到了windows的资源监控,我比较BT,不喜欢用loadrunner的监控,喜欢自己开启计数器,方法不用说了吧,生成csv文件的命令如下:

relog 001.blg -f CSV -o WINNMON.csv

 

 

这里附带说起另外一个话题,如果只是监控一台服务器,这事容易,如果要监控很多台呢,光是把mynmon.sh放上去,启动起来,估计都能把你搞崩溃了。如何自动上传文件,自动执行,自动停止脚本,自动取下结果,这是另外一件事情,有兴趣的同学可以搜搜winscp就会有法子了。

 

 附件:

http://download.csdn.net/detail/testingba/4427796




 

这篇关于资源监控_自己编写一个nmon的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/847078

相关文章

C++中RAII资源获取即初始化

《C++中RAII资源获取即初始化》RAII通过构造/析构自动管理资源生命周期,确保安全释放,本文就来介绍一下C++中的RAII技术及其应用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、核心原理与机制二、标准库中的RAII实现三、自定义RAII类设计原则四、常见应用场景1. 内存管理2. 文件操

python编写朋克风格的天气查询程序

《python编写朋克风格的天气查询程序》这篇文章主要为大家详细介绍了一个基于Python的桌面应用程序,使用了tkinter库来创建图形用户界面并通过requests库调用Open-MeteoAPI... 目录工具介绍工具使用说明python脚本内容如何运行脚本工具介绍这个天气查询工具是一个基于 Pyt

MyBatis编写嵌套子查询的动态SQL实践详解

《MyBatis编写嵌套子查询的动态SQL实践详解》在Java生态中,MyBatis作为一款优秀的ORM框架,广泛应用于数据库操作,本文将深入探讨如何在MyBatis中编写嵌套子查询的动态SQL,并结... 目录一、Myhttp://www.chinasem.cnBATis动态SQL的核心优势1. 灵活性与可

JVisualVM之Java性能监控与调优利器详解

《JVisualVM之Java性能监控与调优利器详解》本文将详细介绍JVisualVM的使用方法,并结合实际案例展示如何利用它进行性能调优,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录1. JVisualVM简介2. JVisualVM的安装与启动2.1 启动JVisualVM2

Mybatis嵌套子查询动态SQL编写实践

《Mybatis嵌套子查询动态SQL编写实践》:本文主要介绍Mybatis嵌套子查询动态SQL编写方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、实体类1、主类2、子类二、Mapper三、XML四、详解总结前言MyBATis的xml文件编写动态SQL

使用Python实现实时金价监控并自动提醒功能

《使用Python实现实时金价监控并自动提醒功能》在日常投资中,很多朋友喜欢在一些平台买点黄金,低买高卖赚点小差价,但黄金价格实时波动频繁,总是盯着手机太累了,于是我用Python写了一个实时金价监控... 目录工具能干啥?手把手教你用1、先装好这些"食材"2、代码实现讲解1. 用户输入参数2. 设置无头浏

使用Java编写一个字符脱敏工具类

《使用Java编写一个字符脱敏工具类》这篇文章主要为大家详细介绍了如何使用Java编写一个字符脱敏工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、字符脱敏工具类2、测试工具类3、测试结果1、字符脱敏工具类import lombok.extern.slf4j.Slf4j

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

AJAX请求上传下载进度监控实现方式

《AJAX请求上传下载进度监控实现方式》在日常Web开发中,AJAX(AsynchronousJavaScriptandXML)被广泛用于异步请求数据,而无需刷新整个页面,:本文主要介绍AJAX请... 目录1. 前言2. 基于XMLHttpRequest的进度监控2.1 基础版文件上传监控2.2 增强版多

基于.NET编写工具类解决JSON乱码问题

《基于.NET编写工具类解决JSON乱码问题》在开发过程中,我们经常会遇到JSON数据处理的问题,尤其是在数据传输和解析过程中,很容易出现编码错误导致的乱码问题,下面我们就来编写一个.NET工具类来解... 目录问题背景核心原理工具类实现使用示例总结在开发过程中,我们经常会遇到jsON数据处理的问题,尤其是