这一博文,是对上一博文的中两个脚本的细节的分析,内容不多,但是价值不小!
其一,就是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")}}'
希望能够帮助到有需要的你!