上一篇介绍监控固定11211端口的memcache(http://dl528888.blog.51cto.com/2382721/1384341),现在在介绍使用low level discover来监控memcache。

下面是效果图:

1、Memcached 11211 of port Items Status

zabbix企业应用之low level discovery监控memcache

2、Memcached 11211 of Port Status

zabbix企业应用之low level discovery监控memcache

3、Memcached 11211 of port Threads Status

zabbix企业应用之low level discovery监控memcache

4、Memcached 11211 of port Uptime

zabbix企业应用之low level discovery监控memcache

5、Memcached 11211 of port Connections

zabbix企业应用之low level discovery监控memcache

6、Memcached 11211 of port CMD Status(hits/misses)

zabbix企业应用之low level discovery监控memcache

7、Memcached 11211 of port Bytes read/write

zabbix企业应用之low level discovery监控memcache

8、Memcached 11211 of port Bytes use

zabbix企业应用之low level discovery监控memcache

9、Memcached 11211 of port Cmd flush/get/set

zabbix企业应用之low level discovery监控memcache

10、Memcached 11211 of port Auth Status

zabbix企业应用之low level discovery监控memcache

如何实现:

一、客户端

1、监控内容的json化

在客户端里,需要把监控的内容json化展示,然后服务端可以通过正则来过滤出结果

下面在是我的json展示

zabbix企业应用之low level discovery监控memcache

脚本内容如下:

[[email protected] bin]# cat memcache_low_discovery.sh
#!/bin/bash
#Fucation:zabbix low-level discovery
memcache() {
            port=($(sudo netstat -tpln | awk -F "[ :]+" '/[m]emcached/ && /0.0.0.0/ {print $5}'))
            printf '{\n'
            printf '\t"data":[\n'
               for key in ${!port[@]}
                   do
                       if [[ "${#port[@]}" -gt 1 && "${key}" -ne "$((${#port[@]}-1))" ]];then
                          printf '\t {\n'
                          printf "\t\t\t\"{#MEMPORT}\":\"${port[${key}]}\"},\n"
                     else [[ "${key}" -eq "((${#port[@]}-1))" ]]
                          printf '\t {\n'
                          printf "\t\t\t\"{#MEMPORT}\":\"${port[${key}]}\"}\n"
                       fi
               done
                          printf '\t ]\n'
                          printf '}\n'
}
$1

把此文件存放到/usr/local/zabbix/bin里,然后给与755权限,并修改用户与组为zabbix,同时允许zabbix用户无密码运行netstat

echo "zabbix ALL=(root) NOPASSWD:/bin/netstat">>/etc/sudoers

#Disable requiretty

sed -i 's/^Defaults.*.requiretty/#Defaults    requiretty/'/etc/sudoers
2、修改zabbix_agentd.conf文件

在zabbix_agentd.conf最后添加以下内容

UserParameter=memcached_stats[*],(echo stats; sleep 0.1) | telnet 127.0.0.1 $1 2>&1 | awk '/STAT $2 / {print $NF}'
UserParameter=zabbix_low_discovery[*],/bin/bash /usr/local/zabbix/bin/memcache_low_discovery.sh $1

3、重启zabbix服务

ps -ef|grep zabbix|grep -v grep|awk '{print $2}'|xargs kill -9
/usr/local/zabbix/sbin/zabbix_agentd -c /usr/local/zabbix/conf/zabbix_agentd.conf

二、服务端

1、模板导入

把Template memcached Auto Discovery导入到zabbix里(模板在附件),具体操作不介绍。

2、设置正则

在“管理”=》“一般”=》“正则表达式”里,选择“新的正则表达式”

然后设置类似如下

zabbix企业应用之low level discovery监控memcache

3、主机关联模板

把需要监控memcache实例的主机管理模板即可监控,默认是3600秒后自动更新,如下图

zabbix企业应用之low level discovery监控memcache

为什么设置3600秒?原因是如果设置时间过短,比如你设置60s,一个是服务器的压力大,一个是如果你检测的端口突然当掉了,还没有来的急报警,主机通过json来获取不到这个信息,就认为没有这个端口,模板里会自动关闭这个监控项的内容(默认保留30天,然后自动删除),这样报警功能就基本没有了,所以还是发现的间隔时间长一些比较好。