Zabbix-2.X/3.X监控工具监控Redis以及zabbix Redis监控模板下载

为了监控Redis3的运行状况,去zabbix官网查找资料,根据提示,找到了这个项目:https://github.com/blacked/zbx_redis_template

但是文档和内容已经不匹配了,比如这个配置项:

hostname = ‘redis.srv.name‘	# Name of monitored server, like it shows in zabbix web ui

  

试验了

trap-message mode 和 Zabbix Agent mode

均以失败告终,然后继续谷歌,直到找到了21运维上的这篇文章:Zabbix-2.X/3.X监控工具监控Redis以及zabbix Redis监控模板下载

按照作者的步骤,做一些小的修改就可以正常的监控起来了。感谢原作者的分享!

以下为文章原文,结合我自己的实际情况做了修改:

本案例以Zabbix-2.2.2为监控平台进行创建,该方法对于zabbix 2.X以及3.X的方法也是一样可以使用,只不过zabbix 2.x平台导入模板的时候,需要编辑模板xml文件将version 3.0改成2.0才可以导入,否则出错。如zabbix  V3.X,则可以直接导入并按照如下方法配置使用。这里只是一个通用操作,如需更加完善功能可以自己添加监控项以及触发器等。下边说下详细操作监控Redis方法。

1.导入模板

下载链接: http://pan.baidu.com/s/1pLlFTsZ 密码: nfp7 ,也可以在这里下载:zabbix3.x监控reddis模板注意自己监控平台版本,低于3.0的需要编辑xml改成2.0后再去导入。

2.创建采集脚本

我的监控采集脚本都放到了/etc/zabbix/script/redis/,在这里创建脚本保存shell脚本:
vim redis.sh

#!/bin/bash
REDISPATH="/usr/local/bin/redis-cli"
HOST="127.0.0.1"
PORT="6379"
REDIS_PA="$REDISPATH -h $HOST -p $PORT info"
if [[ $# == 1 ]];then
    case $1 in
 cluster)
        result=`$REDIS_PA|/bin/grep cluster|awk -F":" ‘{print $NF}‘`
            echo $result
            ;;
 uptime_in_seconds)
        result=`$REDIS_PA|/bin/grep uptime_in_seconds|awk -F":" ‘{print $NF}‘`
            echo $result
            ;;
 connected_clients)
        result=`$REDIS_PA|/bin/grep connected_clients|awk -F":" ‘{print $NF}‘`
            echo $result
            ;;
 client_longest_output_list)
        result=`$REDIS_PA|/bin/grep client_longest_output_list|awk -F":" ‘{print $NF}‘`
            echo $result
            ;;
 client_biggest_input_buf)
        result=`$REDIS_PA|/bin/grep client_biggest_input_buf|awk -F":" ‘{print $NF}‘`
            echo $result
            ;;
 blocked_clients)
        result=`$REDIS_PA|/bin/grep blocked_clients|awk -F":" ‘{print $NF}‘`
            echo $result
            ;;
#内存
 used_memory)
        result=`$REDIS_PA|/bin/grep used_memory|awk -F":" ‘{print $NF}‘|awk ‘NR==1‘`
            echo $result
            ;;
 used_memory_human)
        result=`$REDIS_PA|/bin/grep used_memory_human|awk -F":" ‘{print $NF}‘|awk -F‘K‘ ‘{print $1}‘`
            echo $result
            ;;
 used_memory_rss)
        result=`$REDIS_PA|/bin/grep used_memory_rss|awk -F":" ‘{print $NF}‘`
            echo $result
            ;;
 used_memory_peak)
        result=`$REDIS_PA|/bin/grep used_memory_peak|awk -F":" ‘{print $NF}‘|awk ‘NR==1‘`
            echo $result
            ;;
 used_memory_peak_human)
        result=`$REDIS_PA|/bin/grep used_memory_peak_human|awk -F":" ‘{print $NF}‘|awk -F‘K‘ ‘{print $1}‘`
            echo $result
            ;;
 used_memory_lua)
        result=`$REDIS_PA|/bin/grep used_memory_lua|awk -F":" ‘{print $NF}‘`
            echo $result
            ;;
 mem_fragmentation_ratio)
        result=`$REDIS_PA|/bin/grep mem_fragmentation_ratio|awk -F":" ‘{print $NF}‘`
            echo $result
            ;;
#rdb
 rdb_changes_since_last_save)
        result=`$REDIS_PA|/bin/grep rdb_changes_since_last_save|awk -F":" ‘{print $NF}‘`
            echo $result
            ;;
 rdb_bgsave_in_progress)
        result=`$REDIS_PA|/bin/grep rdb_bgsave_in_progress|awk -F":" ‘{print $NF}‘`
            echo $result
            ;;
 rdb_last_save_time)
        result=`$REDIS_PA|/bin/grep rdb_last_save_time|awk -F":" ‘{print $NF}‘`
            echo $result
            ;;
 rdb_last_bgsave_status)
        result=`$REDIS_PA|/bin/grep -w "rdb_last_bgsave_status" | awk -F‘:‘ ‘{print $2}‘ | /bin/grep -c ok`
            echo $result
            ;;
 rdb_current_bgsave_time_sec)
        result=`$REDIS_PA|/bin/grep -w "rdb_current_bgsave_time_sec" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
#rdbinfo
 aof_enabled)
        result=`$REDIS_PA|/bin/grep -w "aof_enabled" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 aof_rewrite_scheduled)
        result=`$REDIS_PA|/bin/grep -w "aof_rewrite_scheduled" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 aof_last_rewrite_time_sec)
        result=`$REDIS_PA|/bin/grep -w "aof_last_rewrite_time_sec" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 aof_current_rewrite_time_sec)
        result=`$REDIS_PA|/bin/grep -w "aof_current_rewrite_time_sec" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 aof_last_bgrewrite_status)
        result=`$REDIS_PA|/bin/grep -w "aof_last_bgrewrite_status" | awk -F‘:‘ ‘{print $2}‘ | /bin/grep -c ok`
            echo $result
            ;;
#aofinfo
 aof_current_size)
        result=`$REDIS_PA|/bin/grep -w "aof_current_size" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 aof_base_size)
        result=`$REDIS_PA|/bin/grep -w "aof_base_size" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 aof_pending_rewrite)
        result=`$REDIS_PA|/bin/grep -w "aof_pending_rewrite" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 aof_buffer_length)
        result=`$REDIS_PA|/bin/grep -w "aof_buffer_length" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 aof_rewrite_buffer_length)
        result=`$REDIS_PA|/bin/grep -w "aof_rewrite_buffer_length" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 aof_pending_bio_fsync)
        result=`$REDIS_PA|/bin/grep -w "aof_pending_bio_fsync" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 aof_delayed_fsync)
        result=`$REDIS_PA|/bin/grep -w "aof_delayed_fsync" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
#stats
 total_connections_received)
        result=`$REDIS_PA|/bin/grep -w "total_connections_received" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 total_commands_processed)
        result=`$REDIS_PA|/bin/grep -w "total_commands_processed" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 instantaneous_ops_per_sec)
        result=`$REDIS_PA|/bin/grep -w "instantaneous_ops_per_sec" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 rejected_connections)
        result=`$REDIS_PA|/bin/grep -w "rejected_connections" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 expired_keys)
        result=`$REDIS_PA|/bin/grep -w "expired_keys" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 evicted_keys)
        result=`$REDIS_PA|/bin/grep -w "evicted_keys" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 keyspace_hits)
        result=`$REDIS_PA|/bin/grep -w "keyspace_hits" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 keyspace_misses)
        result=`$REDIS_PA|/bin/grep -w "keyspace_misses" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 pubsub_channels)
        result=`$REDIS_PA|/bin/grep -w "pubsub_channels" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 pubsub_channels)
        result=`$REDIS_PA|/bin/grep -w "pubsub_channels" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 pubsub_patterns)
        result=`$REDIS_PA|/bin/grep -w "pubsub_patterns" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 latest_fork_usec)
        result=`$REDIS_PA|/bin/grep -w "latest_fork_usec" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 connected_slaves)
        result=`$REDIS_PA|/bin/grep -w "connected_slaves" | awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 master_link_status)
        result=`$REDIS_PA|/bin/grep -w "master_link_status"|awk -F‘:‘ ‘{print $2}‘|/bin/grep -c up`
            echo $result
            ;;
 master_last_io_seconds_ago)
        result=`$REDIS_PA|/bin/grep -w "master_last_io_seconds_ago"|awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 master_sync_in_progress)
        result=`$REDIS_PA|/bin/grep -w "master_sync_in_progress"|awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 slave_priority)
        result=`$REDIS_PA|/bin/grep -w "slave_priority"|awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
#cpu
 used_cpu_sys)
        result=`$REDIS_PA|/bin/grep -w "used_cpu_sys"|awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 used_cpu_user)
        result=`$REDIS_PA|/bin/grep -w "used_cpu_user"|awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 used_cpu_sys_children)
        result=`$REDIS_PA|/bin/grep -w "used_cpu_sys_children"|awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
 used_cpu_user_children)
        result=`$REDIS_PA|/bin/grep -w "used_cpu_user_children"|awk -F‘:‘ ‘{print $2}‘`
            echo $result
            ;;
        *)
        echo "Usage:$0{uptime_in_seconds|connected_clients|client_longest_output_list|client_biggest_input_buf|blocked_clients|used_memory|used_memory_human|used_memory_rss|used_memory_peak|used_memory_peak_human|used_memory_lua|mem_fragmentation_ratio|rdb_changes_since_last_save|rdb_bgsave_in_progress|rdb_last_save_time|rdb_last_bgsave_status|rdb_current_bgsave_time_sec|aof_enabled|aof_rewrite_scheduled|aof_last_rewrite_time_sec|aof_current_rewrite_time_sec|aof_last_bgrewrite_status|aof_current_size|aof_base_size|aof_pending_rewrite|aof_buffer_length|aof_rewrite_buffer_length|aof_pending_bio_fsync|aof_delayed_fsync|rejected_connections|instantaneous_ops_per_sec|total_connections_received|total_commands_processed|expired_keys|evicted_keys|keyspace_hits|keyspace_misses|pubsub_channels|pubsub_patterns|latest_fork_usec|connected_slaves|master_link_status|master_sync_in_progress|master_last_io_seconds_ago|connected_slaves|slave_priority|used_cpu_user|used_cpu_sys|used_cpu_sys_children|used_cpu_user_children}"
        ;;
esac
#db0:key
        elif [[ $# == 2 ]];then
case $2 in
  keys)
        result=`$REDIS_PA| /bin/grep -w "db0"| /bin/grep -w "$1" | /bin/grep -w "keys" | awk -F‘=|,‘ ‘{print $2}‘`
            echo $result
            ;;
 expires)
        result=`$REDIS_PA| /bin/grep -w "db0"| /bin/grep -w "$1" | /bin/grep -w "expires" | awk -F‘=|,‘ ‘{print $4}‘`
            echo $result
            ;;
 avg_ttl)
        result=`$REDIS_PA|/bin/grep -w "db0"| /bin/grep -w "$1" | /bin/grep -w "avg_ttl" | awk -F‘=|,‘ ‘{print $6}‘`
            echo $result
            ;;
          *)
     echo "Usage:$0{db0 keys|db0 expires|db0 avg_ttl}"
        ;;
esac
fi

赋予权限:chmod +x redis.sh

3.编辑agentd配置文件


cd /etc/zabbix/zabbix_agentd.d/

vim redis.conf

#监控redis状态,我们可以根据这个参数对应的监控项创建redis状态触发器。
UserParameter=redis.status,/usr/local/bin/redis-cli -h 127.0.0.1 -p 6379 ping |grep -c PONG
#item参数如何get
UserParameter=redis_info[*],/etc/zabbix/script/redis/redis.sh $1 $2 

重启agentd服务,使之生效。

systemctl restart zabbix-agent.service

然后到zabbix的web界面,配置、主机、点击主机名称,然后点击模板,在文本框中输入redd,自动搜索出reddis的模板,点击选择,点击添加,点击更新。

然后到zabbix的web界面,管理,一般,其他,修改此项设置:

刷新不支持的监控项目(秒) ,默认600秒,我改成60。

此时再去查看该主机的最新数据,就可以看到监控信息了:

原文地址:https://www.cnblogs.com/lvcisco/p/10309238.html

时间: 2024-11-06 07:35:24

Zabbix-2.X/3.X监控工具监控Redis以及zabbix Redis监控模板下载的相关文章

zabbix监控单机多实例redis脚本

zabbix监控单机多实例redis脚本 公司节省成本,充分利用资源,部署了单机多实例的线上情况.作为python新手,果断决定写个很low的脚本,然后实现监控功能. 下面这个脚本实现了,discovery自动发现,然后通过一个status监控实现了,其它监控信息的自动汇报功能.其中很low的地方在于,每个主机上的脚本必须定义本地的redis信息,比如端口,密码之类的:其实这个可以通过配置中心获取的,但是因为分享出来,所以就写了个定义的实例:还有一点大神都一般自己写socket发送数据,我这里很

网站监控系统安装部署(zabbix,nagios)

zabbix分布式监控系统安装部署 官方网站链接 https://www.zabbix.com/documentation/2.0/manual/installation 安装环境说明 参考地址 http://mayulin.blog.51cto.com/1628315/514371 虚拟机两台 zabbix_server 192.168.50.141 zabbix_agentd 192.168.50.139 os:CentOS 6.3 x64 软件: zabbix-2.0.6 需求软件:htt

为redis主机添加redis监控

一) 环境准备 1.确认安装了 python 2.7 及更高版本 二)脚本上传Proxy discovery_redis.py 1. 添加权限:cd /usr/local/zabbix/scripts/ chown zabbix:zabbix /usr/local/zabbix/scripts/* chmod u+x /usr/local/zabbix/scripts/* 2. 修改配置文件参数,红色部分为redis的密码:vim  userparameter_redis.conf 3. 配置文

开源监控系统中 Zabbix 和 Nagios 哪个更好?

监控平台的话,各有优劣,但基本都可以满足需求.等达到一定监控指标后,发现,最困难的是监控项目的管理. CMDB中小规模(服务器<=1k):Zabbix大规模(1k>=服务器<=10k):Nagios进行二次开发超大规模(服务器>=10k):开发适应自己平台的监控软件吧另推荐个牛逼的东西:http://prometheus.io 作者:好撑链接:https://www.zhihu.com/question/19973178/answer/131911060来源:知乎著作权归作者所有.

运维监控平台之zabbix详解1

本来是想一篇文章介绍完的,写着写着发现篇幅太长,所以决定还是分两篇来介绍,本次软件所用的版本信息如下(基于LNMP环境),操作系统centos6.7 nginx-1.6.3.tar.gz php-5.6.24.tar.gz mysql-5.5.49-linux2.6-x86_64.tar.gz zabbix-3.0.4.tar.gz (zabbix-3以上版本之支持php5.4以上环境) LNMP环境搭建不再这里说明了,如果不懂的看本人之前写的nginx+php,这里简单介绍下php编译 [[e

zabbix监控之二----Zabbix受控端及监控项

4.station32受控端安装zabbix 4.1:下载所需要用的的程序包:只有受控端是主动模式时才需要装zabbix-sender [[email protected]]# yum -y localinstall \ zabbix-2.2.3-1.el6.x86_64.rpm\               # 主程序server端/agent端都需要 zabbix-agent-2.2.3-1.el6.x86_64.rpm\         # 受控端安装agent程序 zabbix-send

企业级监控软件使用zabbix key监控nginx status各种状态

因业务需要需要用zabbix来监控nginx status,具体是如下的做法: 1. 首先在nginx的配置文件中添加如下内容,需要注意的是nginx的文件格式,在allow中我们需要注意的是需要添加zabbix server的IP地址,不然无法采集到数据, 2. 重启nginx服务器查看nginx服务器是否能正常打开, Nginx status状态说明: Active connections: 35 对后端发起的活动链接数 server accepts handled requests 186

centos 监控cacti/nagios/zabbix 第三十四节课

centos   监控cacti/nagios/zabbix   第三十四节课 上半节课 下半节课 f

Linux监控软件之 Zabbix

一.简介 Zabbix是一个企业级的开源分布式监控解决方案,由一个国外的团队持续维护更新,软件可以自由下载使用,运作团队靠提供收费的技术支持赢利.Zabbix通过C/S模式采集数据,通过B/S模式在web端展示和配置. 官方网站:http://www.zabbix.com 官方文档:http://www.zabbix.com/documentation/2.0/manual/quickstart 1.功能 具备常见的商业监控软件所具备的功能(主机的性能监控.网络设备性能监控.数据库性能监控.FT