您的位置:首页 > 运维架构

简单监控脚本细节分析

2017-11-07 09:46 288 查看
这一博文,是对上一博文的中两个脚本的细节的分析,内容不多,但是价值不小!

其一,就是CPU的统计利用率,我采用的是top指令。计算用户态和内核态的使用率之和。

function cpuSts(){
content=`top -b -n 1| grep "Cpu(s)"`
##echo $content
cpup=`echo ${content#*:}`
cpuu=`echo ${cpup%us*}`
cpuss=`echo ${cpup#*,}`
cpus=`echo ${cpuss%sy*}`
us=`echo "$cpuu" | sed 's/^[ \t]*//g'`
sy=`echo "$cpus" | sed 's/^[ \t]*//g'`
#echo $us
ius=`echo $us |awk -F ' ' '{print $2}'`
#echo $ius
#echo $sy
isy=`echo $sy |awk -F ' ' '{print $2}'`
#echo $isy

fius=`echo $ius |awk -F '%' '{print $1}'`
fisy=`echo $isy |awk -F '%' '{print $1}'`
#total=`echo $fius+$fisy | bc`
#total=$(echo "$total * 100" | bc)
total=`echo "$fius $fisy" | awk '{printf("%0.2f\n",$1+$2)}'`
#total=`echo "$total * 100" | bc`
total=`echo "$total 100" | awk '{printf("%0.2f\n",$1*$2)}'`
echo "$total"
}


top参数不带-b的情况下,cpuSts不能作为后台程序被调度执行。否则会爆出下面的错误:

[tomcat@p0-tkonline-css-web01 ~]$ tailf nohup.out
top: failed tty get

(Not all processes could be identified, non-owned process info
will not be shown, you would have to be root to see it all.)


另外,还有一点,关于上述的脚本,就是浮点数运算,在后台进程中进行时,不能用bc指令,我们可以采用awk的函数。因为bc在后台脚本运行时,会爆出下面的错误:

[tomcat@p0-tkonline-css-web01 ~]$ tailf nohup.out
(standard_in) 1: syntax error
(Not all processes could be identified, non-owned process info
will not be shown, you would have to be root to see it all.)


其二,就是mongo数据库操作,统计一个时间段内的QA数量,脚本如下:

#!/bin/sh
mongo 100.126.22.156/tkrobotkdb -u xxx -p xxxx --eval 'et=new Date();st=new Date();st.setMinutes(st.getMinutes()-10);db.messageHistory.find({"channel":{"$nin":["CSS","SYS"]},"createTime":{"$gte":st,"$lte":et}}).count()'


这个脚本的重点是,mongo的eval参数,在这个参数后面,可以写很复杂的mongo shell脚本。

正如我这里的,在mongo shell里面,设置两个时间,分别表示起始时间和结束时间,相隔10分钟,然后在messageHistory这个collection里面查找相关数据在这个10分钟的间隔里面的数量,这里实现每10分钟统计一次QA数量。

PS: 按条件导出mongo中指定的内容:

./mongoexport -h 100.126.22.156 -u xxx -p yyy -d tkrobotkdb -c messageHistory -o /home/tomcat/cshmessageHistory.json --type json -f "msgInId,createTime,type" -q '{"channel":"zzz","createTime" : { $gt: ISODate("2017-11-02T06:00:00Z")}}'


希望能够帮助到有需要的你!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: