zabbix监控redis多实例cpu mem-自动发现
1.自动发现实例端口脚本,用于zbx item prototypes
#!/bin/bash
REDIS_PORT=`ps aux |grep redis-server | grep -v 'grep'|awk -F'[:]' '{print $4}'`
COUNT=`echo "$REDIS_PORT" | wc -l`
INDEX=0
echo '{"data":['
echo "$REDIS_PORT" | while read LINE; do
echo -n '{"{#PORTNUM}":"'$LINE'"}'
INDEX=`expr $INDEX + 1`
if [ $INDEX -lt $COUNT ]; then
echo ','
fi
done
echo ']}'
- 运行结果如下:
{"data":[
{"{#PORTNUM}":"6379"},
{"{#PORTNUM}":"6380"}]}
2.crontab周期取数脚本,每1分钟运行两次,zbx每30s取值一次
* * * * * /bin/sh /usr/local/zabbix/bin/redis_port_cron.sh
- 脚本
#!/bin/bash
# redis_port_cron.sh
# 获取CPU使用临时存储
for (( i=0;i < 2;i=(i+1) ));do
TMP_DATA=/tmp/redis_cpu_util_tmp.log
DEST_DATA=/tmp/redis_cpu_util.log
echo "REDIS_PORT CPU_percent MEM_percent MEM_GB" > $TMP_DATA
pid_array=`ps aux |grep redis-server | grep -v 'grep' | awk '{print $2}'`
for pid in ${pid_array[@]}
do
redis_port=`top -c -b -n 1 -p $pid|tail -n 2 |awk -F'[:]' 'NR==1{print $3}'`
redis_cpu_util=`top -c -b -n 1 -p $pid | tail -2|awk 'NR==1{print $9}'`
redis_mem_util=`top -c -b -n 1 -p $pid | tail -2|awk 'NR==1{print $10}'`
redis_mem_MAX=`awk '($1 == "MemTotal:"){print $2/1048576}' /proc/meminfo`
redis_mem_GB=`awk 'BEGIN{print "'$redis_mem_MAX'"*"'$redis_mem_util'"/100}'`
echo $redis_port $redis_cpu_util $redis_mem_util $redis_mem_GB >> $TMP_DATA
done
sleep 20
done
[ -e $TMP_DATA ]&& mv $TMP_DATA $DEST_DATA
- 运行结果如下,第一列是端口号,第二列是CPU百分比,第三列是内存百分比,将内存转换成GB:
REDIS_PORT CPU_percent MEM_percent MEM_GB
6379 0.0 0.8 0.0146658
6380 0.0 0.4 0.00733288
3.zbx传key值
#!/bin/bash
# redis_custom_check.sh
ZBX_REDIS_PORT="$1"
ZBX_REDIS_KEY="$2"
# source data file
SOURCE_DATA=/tmp/redis_cpu_util.log
# No data file to read from
if [ ! -f "$SOURCE_DATA" ]; then
echo "NO DATA FILE FOR READ"
exit 1
fi
# 1st check the device exists and gets data gathered by cron job
port_count=$(grep -Ec "^$ZBX_REDIS_PORT" $SOURCE_DATA)
if [ $port_count -eq 0 ]; then
echo "NO DATA FOR READ"
exit 1
fi
# 2nd grab the data from the source file
case $ZBX_REDIS_PORT in
CPU_percent ) grep -E "^$ZBX_REDIS_PORT" $SOURCE_DATA | awk '{print $2}';;
MEM_percent ) grep -E "^$ZBX_REDIS_PORT" $SOURCE_DATA | awk '{print $3}';;
MEM_GB) grep -E "^$ZBX_REDIS_PORT" $SOURCE_DATA | awk '{print $4}';;
*) echo "ERROR_WRONG_PARAM"; exit 1;;
esac
exit 0
4.重启zbx agent 测试key
UserParameter=redis.port.discovery,/bin/sh /usr/local/zabbix/bin/redis_port_discovery.sh
UserParameter=redis.instance.util[*],/bin/sh /usr/local/zabbix/bin/redis_custom_check.sh $1 $2
- 测试key
zabbix_get -s 127.0.0.1 -k redis.instance.util[6379,CPU_percent]
zabbix_get -s 127.0.0.1 -k redis.instance.util[6379,MEM_GB]
zabbix_get -s 127.0.0.1 -k redis.instance.util[6379,MEM_percent]
[root@GZ-LT-DB-redis01 zabbix_agentd.conf.d]# zabbix_get -s 127.0.0.1 -k redis.instance.util[6379,CPU_percent]
0.0
[root@GZ-LT-DB-redis01 zabbix_agentd.conf.d]# zabbix_get -s 127.0.0.1 -k redis.instance.util[6379,MEM_GB]
0.0146658
[root@GZ-LT-DB-redis01 zabbix_agentd.conf.d]# zabbix_get -s 127.0.0.1 -k redis.instance.util[6379,MEM_percent]
0.8
5.建item和图形



zabbix监控redis多实例cpu mem-自动发现的更多相关文章
- zabbix监控redis多实例(low level discovery)
对于多实例部署的tomcat.redis等应用,可以利用zabbix的low level discovery功能来实现监控,减少重复操作. 注:Zabbix版本: Zabbix 3.0.2 一.服务 ...
- zabbix监控vCenter报错,无法自动发现主机
公司机房停电检修,检修完成后重新上电,发现VCSA起不来了,尝试多次无法解决,无奈只好重装.重装VCSA 6.5U2之后又发现无法自动发现主机,报错如下: 'config.vpxd.stats.max ...
- 01:zabbix监控redis
一.zabbix 自动发现并监控redis多实例 1.1 编写脚本 1.1.1 redis_low_discovery.sh 用于发现redis多实例 [root@redis02 homed]# ca ...
- 监控redis进程,如果没有自动重启
监控redis进程,如果没有自动重启 #Time:2016-01-22#Version:1.0 #Author:chh-huang #设置环境变量source /etc/profile#source ...
- Zabbix应用六:Zabbix监控Redis
利用Zabbix监控Redis Zabbix监控redis就比较简单了,因为zabbix官方提供了监控redis的模版和脚本,而且脚本有nodejs和python两种,下载地址:https://git ...
- Zabbix整合MegaCLI实现物理硬盘的自动发现和监控
MegaCLI是LSI提供的用户空间管理RAID卡(LSI芯片)工具,适用于大多数的Dell服务器. MegaCLI介绍: http://zh.community.dell.com/techcente ...
- Zabbix 监控redis
Zabbix 监控redis 1.监控脚本,github上的 [root@localhost ~]# cat /etc/zabbix/script/redis-status.sh #!/bin/bas ...
- 最新 centos7下zabbix 监控redis状态
准备 先准备两台服务器,已经部署好了zabbix-sever和zabbix-agent zabbix-server 192.168.1.70 centos7.2 zabbix-agent 192.16 ...
- 如何用zabbix监控mysql多实例
agent上起了多了 mysql实例,占用不同的端口,agent 仅在初始状况下,塞入脚本和 键配置,然后重启. 以后维护的时候(mysql端口变动),要做到 不能 动agent,力争 只在 web端 ...
随机推荐
- 如何打开 Visual Studio 的 Dump,适用于调试 appcrash,exception
https://keithbabinec.com/2018/06/12/how-to-capture-and-debug-net-application-crash-dumps-in-windows/ ...
- 第 3 篇:实现博客首页文章列表 API
作者:HelloGitHub-追梦人物 文中所涉及的示例代码,已同步更新到 HelloGitHub-Team 仓库 此前在讨论基于模板引擎的开发方式和 django-rest-framework 开发 ...
- OpenCV学习(4)——动态结构
学习一个新知识,无外乎学习它本身和它的工具.OpenCV提供许多内置的结构及处理函数,非常值得学习. 内存存储 在OpenCV中,内存存储器是一个可以用来存储序列.数组和图像的动态增长的数据结构.它由 ...
- ps 和 top
ps 进程和线程的关系: (1)一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程. (2)资源分配给进程,同一进程的所有线程共享该进程的所有资源. (3)处理机分给线程,即真正在处 ...
- 狄慧201771010104《面向对象程序设计(java)》第十六周学习总结
实验十六 线程技术 实验时间 2017-12-8 一.知识点总结: 1.程序与进程的概念 ‐程序是一段静态的代码,它是应用程序执行的蓝本. ‐进程是程序的一次动态执行,它对应了从代码加载.执行至执行 ...
- Shiro(一):Shiro介绍及主要流程
什么是Shiro Apache Shiro是一个强大且灵活的开源安全框架,易于使用且好理解,撇开了搭建安全框架时的复杂性. Shiro可以帮助我们做以下几件事: 认证使用者的身份 提供用户的访问控制, ...
- 解决iframe跨域刷新的问题
用iframe的location.reload(true); 方法来刷新外部URL会报 Blocked a frame with origin xxxx from accessing a cross- ...
- Northwestern European Regional Contest 2014 Gym - 101482
Gym 101482C Cent Savings 简单的dp #include<bits/stdc++.h> #define inf 0x3f3f3f3f #define inf64 0x ...
- 模板引擎 Thymeleaf 动态渲染 HTML
1.添加依赖 <!-- Thymeleaf 模板引擎 --> <dependency> <groupId>org.thymeleaf</groupId> ...
- git使用-忽略文件更新的几种方法
有几种情况我们不希望本地文件在 git 里面得到更新. 一.情况:始终不需要git跟踪本地的一些文件 方法:使用.gitignore文件忽略 解释: 使用git init操作创建git控制管理之后,默 ...