当前位置:首页 » 《休闲阅读》 » 正文

Linux性能统计工具_chuntian_tester的博客

25 人参与  2022年02月16日 09:10  分类 : 《休闲阅读》  评论

点击全文阅读


有时候测试后端服务需要监控该服务消耗的系统资源,这个时候就需要自己开发工具来满足性能统计需求了:

以下demo以收集某个服务消耗的系统cpu和内存为示例:

通过条件控制

#!/bin/bash
k=$1
if [ -z $k ]
then
        echo "need  a PID or process name as a argument!"
else
        count=`ps -ef | grep -c $k`
        #echo "进程数为:$count"
        if [ $count -lt 4 ]
        then
                echo "the PID or processs name $k is not exist!!"
        else
                top -n 20 -d 1 -b | grep  --line-buffered $k | awk 'BEGIN{OFS="\t";print "%CPU","%MEM"} {print $9,$10} {CPU+=$9;MEM+=$10} END{print ".........."; print "   avg"; print CPU/NR,MEM/NR}'
        fi
fi

或者结合函数调用: 

  1 #!/bin/bash
  2 function cpu_mem(){
  3 local proc=$1
  4 local duration=$2
  5 #判断是否有参数,没有就提醒追加pid或者进程名
  6 [ -z $proc ] && { echo "need a PID or process name as a argument!!please append the argument after the runing-script command~~";return 1; }
  7 #判断参数中是否带了监控时长,如果没有带监控时长参数,则使用系统默认时长10s
  8 [ -z $duration ] && duration=10
  9 echo "统计进程:$proc,监控时长:$duration秒!"
 10 
 11 top -n $duration -d 1 -b | grep -i --line-buffered $proc | awk 'BEGIN{OFS="\t";print "%CPU","%MEM"} {print $9,$10} {CPU+=$9;MEM+=$10} END{print "...........";print "     avg";print CPU/NR,MEM/NR}'
 12 
 13 }
 14 cpu_mem $1 $2

 踩过的坑:bash脚本中的缩进空格一定要严格查看,不然很难发现报错信息...


点击全文阅读


本文链接:http://zhangshiyu.com/post/34833.html

时长  监控  进程  
<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

关于我们 | 我要投稿 | 免责申明

Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1