用shell脚本监控memcache缓存命中率,监控memcached进程是否正常telnet通,实例是否存在,还要监控缓存命中率。 通过check_tcp脚本获取memcached的stats信息,然后将该信息格式化成一个字符串,将get_hits比上cmd_gets就能得到缓存命中率。 多台服务器开着多个memcached进程,除了要监控是否正常telnet通,实例是否存在,还要监控缓存命中率。 针对缓存命中率进行报警。
还要实现nagios的报警格式,以及性能数据的输出,支持pnp绘图。
代码:
#!/bin/bash
####################### #检查memcached的命中率 #加载nagios自带utils.sh ###################### source/usr/local/nagios/libexec/utils.sh print_usage() { echo"check_memcached -H IP -P port -w warning -c critical" } ################### #获取命令行执行参数 ################### whiletest-n "$1";do case"$1"in -H) host=$2 shift ;; -P) port=$2 shift ;; -w) warning=$2 shift ;; -c) critical=$2 shift ;; *) echo"Unknown argument:$1" print_usage exit$STATE_UNKNOWN ;; esac shift done ######################## #function div_f() #检查参数,返回两个数字比 ######################## functiondiv_f() { ref=`awk-vnum_a=$1 -vnum_b=$2 'BEGIN{printf "%0.2f \n",num_a/num_b}'`; echo$ref; } ################## #得到命中率函数 ################## functiongetMemcachedHits() { memcachedinfo=`/usr/local/nagios/libexec/check_tcp-H $host -p $port -E -s'stats\r\nquit\r\n'-e 'uptime'| tr"\r""@"` get_hits=`echo$memcachedinfo | grep-o "@ STAT get_hits [0-9]*"| awk'{print $4}'` cmd_get=`echo$memcachedinfo | grep-o "@ STAT cmd_get [0-9]*"| awk'{print $4}'` div_f $get_hits $cmd_get; } hits=`getMemcachedHits $host $port`; ################## #得到命中率所在区间 ################## functionre_rang() { rang=$hits; interval_a=$critical; interval_b=$warningl if[[ $rang < $interval_a ]];then echo"0"; elif[[ $rang < $interval_b ]];then echo"1"; elif[[ $rang > $interval_b ]]||[[ $rang == $interval_b ]] ;then echo"2"; else return; fi } res=`re_rang $critical $warning $hits`; case"$res"in 0) echo"Critical memcached_hits=$hits|memcached_hits=$hits;$warning;$critical;" exit$STATE_CRITICAL ;; 1) echo"Warning memcached_hits=$hits|memcached_hits=$hits;$warning;$critical;" exit$STATE_WARNING ;; 2) echo"Ok memcached_hits=$hits|memcached_hits=$hits;$warning;$critical;" exit$STATE_OK ;; *) echo"Unkown" exit$STATE_UNKNOWN ;; esac (责任编辑:IT) |