redis实例动态监控
##如果一个机器上有好几个redis实例,好多的公司为了充分利用硬件资源通常采用这种方式!这样如果一个一个修改port,然后导入相应的模板,效率太低了,也太笨了!
1:我先在虚拟机上创建4个redis实例,分别在6379,7379,8379,9379端口监听
2:在客户端需要如下:
[root@zabbixclient3 zabbix_agentd.conf.d]# pwd
/usr/local/zabbix/etc/zabbix_agentd.conf.d
[root@zabbixclient3 zabbix_agentd.conf.d]# ll
-rw-r--r-- 1 root root 221 Feb 1 00:32 redis.conf
[root@zabbixclient3 zabbix_agentd.conf.d]# cat redis.conf ##内容如下:
UserParameter=zabbix_low_discovery[*],/bin/bash /usr/local/zabbix/bin/redis_low_discovery.sh $1
UserParameter=redis_stats[*],(echo info; sleep 1) | /usr/local/redis/bin/redis-cli -a redis -p $1 2>&1 |grep $2|cut -d : -f2 ##这里是因为redis实例加了密码,对应空密码的redis实例,只需要telnet 即可,加了密码之后,telnet就不工作了,只好使用redis-cli
Sh脚本内容如下:
[root@zabbixclient3 zabbix_agentd.conf.d]# cd /usr/local/zabbix/bin/
[root@zabbixclient3 bin]# ll
total 548
-rwxr-xr-x 1 zabbix zabbix 1059 Jan 31 23:48 redis_low_discovery.sh
-rwxr-xr-x. 1 root root 245863 Nov 10 10:16 zabbix_get
-rwxr-xr-x. 1 root root 303352 Nov 10 10:16 zabbix_sender
[root@zabbixclient3 bin]# cat redis_low_discovery.sh
#!/bin/bash
#Fucation:mysql low-level discovery
#Script_name redis_low_discovery.sh
redis() {
port=($(sudo netstat -tpln | awk -F "[ :]+" '/redis/ && /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
socket=`ps aux|grep ${port[${key}]}|grep -v grep|awk -F '=' '{print $10}'|cut -d ' ' -f 1`
printf '\t {\n'
printf "\t\t\t\"{#REDISPORT}\":\"${port[${key}]}\"},\n"
else [[ "${key}" -eq "((${#port[@]}-1))" ]]
socket=`ps aux|grep ${port[${key}]}|grep -v grep|awk -F '=' '{print $10}'|cut -d ' ' -f 1`
printf '\t {\n'
printf "\t\t\t\"{#REDISPORT}\":\"${port[${key}]}\"}\n"
fi
done
printf '\t ]\n'
printf '}\n'
}
redis $1 ##尤其要注意这一行!
修改/usr/local/zabbix/etc/zabbix_agentd.conf,将redis.conf include进去!于是增加一行:
Include=/usr/local/zabbix/etc/zabbix_agentd.conf.d/ ##将该目录include进去,则该目录下所有的文件都会被include进去!
把redis_low_discovery.sh文件存放到/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
下面是zabbix server上的配置,首先将模板导入到zabbix server中,步骤省略。。。。。。
尤其要注意该discovery rule,蓝色字体部分必须为空!否则监控不正常工作!
##这里我弄了大概20分钟的时间,后来将蓝色字体部分置空,问题就解决了!当然也可以在zabbix server上check zabbix client的工作情况,主要是通过zabbix_get来检查的,如下(需在zabbix服务端执行):
如果能获取到值,说明是正常的,否则就有问题!
转载至:http://blog.chinaunix.net/xmlrpc.php?r=blog/article&uid=20776139&id=4868392
转载于:https://blog.51cto.com/canonind/1847432