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-自动发现的更多相关文章

  1. zabbix监控redis多实例(low level discovery)

    对于多实例部署的tomcat.redis等应用,可以利用zabbix的low level discovery功能来实现监控,减少重复操作.  注:Zabbix版本: Zabbix 3.0.2 一.服务 ...

  2. zabbix监控vCenter报错,无法自动发现主机

    公司机房停电检修,检修完成后重新上电,发现VCSA起不来了,尝试多次无法解决,无奈只好重装.重装VCSA 6.5U2之后又发现无法自动发现主机,报错如下: 'config.vpxd.stats.max ...

  3. 01:zabbix监控redis

    一.zabbix 自动发现并监控redis多实例 1.1 编写脚本 1.1.1 redis_low_discovery.sh 用于发现redis多实例 [root@redis02 homed]# ca ...

  4. 监控redis进程,如果没有自动重启

    监控redis进程,如果没有自动重启 #Time:2016-01-22#Version:1.0 #Author:chh-huang #设置环境变量source /etc/profile#source ...

  5. Zabbix应用六:Zabbix监控Redis

    利用Zabbix监控Redis Zabbix监控redis就比较简单了,因为zabbix官方提供了监控redis的模版和脚本,而且脚本有nodejs和python两种,下载地址:https://git ...

  6. Zabbix整合MegaCLI实现物理硬盘的自动发现和监控

    MegaCLI是LSI提供的用户空间管理RAID卡(LSI芯片)工具,适用于大多数的Dell服务器. MegaCLI介绍: http://zh.community.dell.com/techcente ...

  7. Zabbix 监控redis

    Zabbix 监控redis 1.监控脚本,github上的 [root@localhost ~]# cat /etc/zabbix/script/redis-status.sh #!/bin/bas ...

  8. 最新 centos7下zabbix 监控redis状态

    准备 先准备两台服务器,已经部署好了zabbix-sever和zabbix-agent zabbix-server 192.168.1.70 centos7.2 zabbix-agent 192.16 ...

  9. 如何用zabbix监控mysql多实例

    agent上起了多了 mysql实例,占用不同的端口,agent 仅在初始状况下,塞入脚本和 键配置,然后重启. 以后维护的时候(mysql端口变动),要做到 不能 动agent,力争 只在 web端 ...

随机推荐

  1. OpenCV学习(2)——一个简单的例子

    光说不练假把式,来看一个简单的例子,了解了解OpenCV.这个小demo没有几行代码,作用是显示项目目录下面的一张图片. #include <opencv2\opencv.hpp> #in ...

  2. 【shell】shell脚本入门

    1. 前言 1.1 为什么学习shell编程 Shell脚本语言是实现Linux/UNIX系统管理及自动化运维所必备的重要工具,Linux/UNIX系统的底层及基础应用软件的核心大部分涉及Shell脚 ...

  3. RHEL6 搭建 keepalived + lvs/DR 集群

    搭建 keepalived + lvs/DR  集群 使用Keepalived为LVS调度器提供高可用功能,防止调度器单点故障,为用户提供Web服务: LVS1调度器真实IP地址为192.168.4. ...

  4. CodeForces - 1102B Array K-Coloring

    B. Array K-Coloring time limit per test2 seconds memory limit per test256 megabytes inputstandard in ...

  5. 15分钟从零开始搭建支持10w+用户的生产环境(四)

    上一篇文章,介绍了这个架构中,WebServer的选择,以及整个架构中扩展时的思路. 原文地址:15分钟从零开始搭建支持10w+用户的生产环境(三)   五.架构实践 前边用了三篇文章,详细介绍了这个 ...

  6. Java——多线程之方法详解

    Java多线程系列文章是Java多线程的详解介绍,对多线程还不熟悉的同学可以先去看一下我的这篇博客Java基础系列3:多线程超详细总结,这篇博客从宏观层面介绍了多线程的整体概况,接下来的几篇文章是对多 ...

  7. 送你一份Redis书单,以后使用缓存的问题不用再问我啦!

    点击蓝色"程序员书单"关注我哟 加个"星标",每天带你读好书!

  8. 001_python变量,if,while

    Python介绍 python的出生与应用 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆(中文名字:龟叔)为了在阿姆斯特丹打发时间, ...

  9. 【HBase】带你了解一哈HBase的各种预分区

    目录 简单了解 概述 设置预分区 一.手动指定预分区 二.使用16进制算法生成预分区 三.将分区规则写在文本文件中 四.使用JavaAPI进行预分区 简单了解 概述 由上图可以看出,每一个表都有属于自 ...

  10. 【Hadoop离线基础总结】Hive的基本操作

    Hive的基本操作 创建数据库与创建数据库表 创建数据库的相关操作 创建数据库:CREATE TABLE IF NOT EXISTS myhive hive创建表成功后的存放位置由hive-site. ...