工具的作用:

1)比“cluster nodes”更为直观的显示结果

2)指出落在同一个IP上的master

3)指出落在同一个IP上的master和slave对

运行效果图:

源代码(可从https://github.com/eyjian/redis-tools下载):

#!/bin/bash
# 源码位置:https://github.com/eyjian/redis-tools
#
# Redis集群部署注意事项:
# 在一个物理IP上部署多个redis实例时,要避免:
# 1) 一对master和slave出现在同一物理IP上(影响:物理机挂掉,部分keys彻底不可用)
# 2) 同一物理IP上出现多个master(影响:物理机挂掉,将导致两对切换)
#
# 使用示例(带一个参数):
# show_redis_map.sh 192.168.0.21:6380
#
# 检查Redis集群master和slave映射关系的命令行工具:
# 1) 查看是否多master出现在同一IP;
# 2) 查看一对master和slave出现在同一IP。
#
# 当同一IP出现二个或多个master,则相应的行标星显示,
# 如果一对master和slave出现在同一IP上,则相应的行标星显示。
#
# 输出效果:
# [01][MASTER] 192.168.0.21:6379 00cc3f37d938ee8ba672bc77b71d8e0a3881a98b
# [02][MASTER] 192.168.0.22:6379 1115713e3c311166207f3a9f1445b4e32a9202d7
# [03][MASTER] 192.168.0.23:6379 5cb6946f46ccdf543e5a1efada6806f3df72b727
# [04][MASTER] 192.168.0.24:6379 b91b1309b05f0dcc1e3a2a9521b8c00702999744
# [05][MASTER] 192.168.0.25:6379 00a1ba8e5cb940ba4171e0f4415b91cea96977bc
# [06][MASTER] 192.168.0.26:6379 64facb201cc5c7d8cdccb5fa211af5e1a04a9786
# [07][MASTER] 192.168.0.27:6379 f119780359c0e43d19592db01675df2f776181b1
# [08][MASTER] 192.168.0.28:6379 d374e28578967f96dcb75041e30a5a1e23693e56
# [09][MASTER] 192.168.0.29:6380 a153d2071251657004dbe77abd10e2de7f0a209a
#
# [01][SLAVE=>MASTER] 192.168.0.21:6380 => 192.168.0.28:6379
# [02][SLAVE=>MASTER] 192.168.0.22:6380 => 192.168.0.25:6379
# [03][SLAVE=>MASTER] 192.168.0.23:6380 => 192.168.0.24:6379
# [04][SLAVE=>MASTER] 192.168.0.24:6380 => 192.168.0.23:6379
# [05][SLAVE=>MASTER] 192.168.0.25:6380 => 192.168.0.22:6379
# [06][SLAVE=>MASTER] 192.168.0.26:6380 => 192.168.0.27:6379
# [07][SLAVE=>MASTER] 192.168.0.27:6380 => 192.168.0.29:6380
# [08][SLAVE=>MASTER] 192.168.0.28:6380 => 192.168.0.21:6379
# [09][SLAVE=>MASTER] 192.168.0.29:6379 => 192.168.0.26:6379 REDIS_CLI=${REDIS_CLI:-redis-cli}
REDIS_IP=${REDIS_IP:-127.0.0.1}
REDIS_PORT=${REDIS_PORT:-6379} function usage()
{
echo "usage: `basename $0` redis_node"
echo "example: `basename $0` 127.0.0.1:6379"
} # with a parameter: single redis node
if test $# -ne 1; then
usage
exit 1
fi # 检查参数
eval $(echo "$1" | awk -F[\:] '{ printf("REDIS_IP=%s\nREDIS_PORT=%s\n",$1,$2) }')
if test -z "$REDIS_IP" -o -z "$REDIS_PORT"; then
echo "parameter error"
usage
exit 1
fi # 确保redis-cli可用
which "$REDIS_CLI" > /dev/null 2>&1
if test $? -ne 0; then
echo -e "\`redis-cli\` not exists or not executable"
exit 1
fi # master映射表,key为master的id,value为master的“ip:port”
declare -A master_map=()
# slave映表,key为master的id,value为slave的“ip:port”
declare -A slave_map=()
master_nodes_str=
master_slave_maps_str= # 找出所有master
masters=`$REDIS_CLI -h $REDIS_IP -p $REDIS_PORT CLUSTER NODES | awk -F[\ \@] '/master/{ printf("%s,%s\n",$1,$2); }' | sort`
for master in $masters;
do
eval $(echo $master | awk -F[,] '{ printf("master_id=%s\nmaster_node=%s\n",$1,$2); }') master_map[$master_id]=$master_node
if test -z "$master_nodes_str"; then
master_nodes_str="$master_node|$master_id"
else
master_nodes_str="$master_node|$master_id,$master_nodes_str"
fi
done # 找出所有slave
# “CLUSTER NODES”命令的输出格式当前有两个版本,需要awk需要根据NF的值做区分
slaves=`$REDIS_CLI -h $REDIS_IP -p $REDIS_PORT CLUSTER NODES | awk -F[\ \@] '/slave/{ if (NF==9) printf("%s,%s\n",$5,$2); else printf("%s,%s\n",$4,$2); }' | sort`
for slave in $slaves;
do
eval $(echo $slave | awk -F[,] '{ printf("master_id=%s\nslave_node=%s\n",$1,$2); }')
slave_map[$master_id]=$slave_node
done for key in ${!master_map[@]}
do
master_node=${master_map[$key]}
slave_node=${slave_map[$key]} if test -z "$master_slave_maps_str"; then
master_slave_maps_str="$slave_node|$master_node"
else
master_slave_maps_str="$slave_node|$master_node,$master_slave_maps_str"
fi
done # 显示所有master
index=1
old_master_node_ip=
master_nodes_str=`echo "$master_nodes_str" | tr ',' '\n' | sort`
for master_node_str in $master_nodes_str;
do
eval $(echo "$master_node_str" | awk -F[\|] '{ printf("master_node=%s\nmaster_id=%s\n", $1, $2); }')
eval $(echo "$master_node" | awk -F[\:] '{ printf("master_node_ip=%s\nmaster_node_port=%s\n", $1, $2); }') tag=
# 同一IP上出现多个master,标星
if test "$master_node_ip" = "$old_master_node_ip"; then
tag=" (*)"
fi printf "[%02d][MASTER] %-20s \033[0;32;31m%s\033[m%s\n" $index "$master_node" "$master_id" "$tag"
old_master_node_ip=$master_node_ip
index=$((++index))
done # 显示所有slave到master的映射
index=1
echo ""
master_slave_maps_str=`echo "$master_slave_maps_str" | tr ',' '\n' | sort`
for master_slave_map_str in $master_slave_maps_str;
do
eval $(echo "$master_slave_map_str" | awk -F[\|] '{ printf("slave_node=%s\nmaster_node=%s\n", $1, $2); }')
eval $(echo "$slave_node" | awk -F[\:] '{ printf("slave_node_ip=%s\nslave_node_port=%s\n", $1, $2); }')
eval $(echo "$master_node" | awk -F[\:] '{ printf("master_node_ip=%s\nmaster_node_port=%s\n", $1, $2); }') tag=
# 一对master和slave出现在同一IP,标星
if test ! -z "$slave_node_ip" -a "$slave_node_ip" = "$master_node_ip"; then
tag=" (*)"
fi n=$(($index % 2))
if test $n -eq 0; then
printf "[%02d][SLAVE=>MASTER] \033[1;33m%21s\033[m => \033[1;33m%s\033[m%s\n" $index $slave_node $master_node "$tag"
else
printf "[%02d][SLAVE=>MASTER] %21s => %s%s\n" $index $slave_node $master_node "$tag"
fi index=$((++index))
done echo ""

查看Redis集群主从对应关系工具的更多相关文章

  1. (转)基于Redis Sentinel的Redis集群(主从&Sharding)高可用方案

    转载自:http://warm-breeze.iteye.com/blog/2020413 本文主要介绍一种通过Jedis&Sentinel实现Redis集群高可用方案,该方案需要使用Jedi ...

  2. 基于Redis Sentinel的Redis集群(主从Sharding)高可用方案(转)

    本文主要介绍一种通过Jedis&Sentinel实现Redis集群高可用方案,该方案需要使用Jedis2.2.2及以上版本(强制),Redis2.8及以上版本(可选,Sentinel最早出现在 ...

  3. 基于Redis Sentinel的Redis集群(主从&Sharding)高可用方案

    本文主要介绍一种通过Jedis&Sentinel实现Redis集群高可用方案,该方案需要使用Jedis2.2.2及以上版本(强制),Redis2.8及以上版本(可选,Sentinel最早出现在 ...

  4. 查看Redis集群所有节点内存工具

    指定集群中任意一个节点,查看集群中所有节点当前已用物理内存.配置的最大物理内存和系统物理内存. ​ ​源码(可从https://github.com/eyjian/redis-tools下载): #! ...

  5. Redis Sentinel的Redis集群(主从&Sharding)高可用方案

    在不使用redis3.0之后版本的情况下,对于redis服务端一般是采用Sentinel哨兵模式,也就是一主多备的方式. 这里,先抛出三个问题, 问题1:单节点宕机数据丢失?问题2:多节点(节点间没有 ...

  6. redis集群主从集群搭建、sentinel(哨兵集群)配置以及Jedis 哨兵模式简要配置

    前端时间项目上为了提高平台性能,为应用添加了redis缓存,为了提高服务的可靠性,redis部署了高可用的主从缓存,主从切换使用的redis自带的sentinel集群.现在权作记录.

  7. redis集群主从中断,报io过高 不错

    问题原因:1.由于这个集群redis操作非常频繁,1分钟操作数据达到1-2G,所有自动aof非常频繁,主从复制打包rdb也非常频繁,之前配置已经无法满足要求报异常如下6943:M 19 Jul 20: ...

  8. Redis集群-主从模式

    1.架构设计 集群在单台主机上模拟搭建6个节点(3主3从的集群): 2.配置 创建与端口相同的文件夹存储Redis配置文件和持久化文件. 目录如下: 每个节点配置文件如下: 节点1: bind 192 ...

  9. redis集群使用Java工具类(Java jedis集群工具类)

    package com.xiaomi.weather.vote.webservices.util.redisCache; import com.google.common.base.Strings; ...

随机推荐

  1. django os.environ慎用setdefault操作环境变量!

    在绝大多数情况下,如果需要在程序运行过程中设置环境变量,使用os.environ.setdefault函数是没有任何问题的,但是有两种场景下setdefault会造成意外的问题,需要慎用: 如果程序执 ...

  2. dev accordionControl panelcontorl 使用

    对于dev的窗体布局我想更系统的专业的学学,不是评自己以往 的经验去做, 所以我看了dev的demo 里边的例子,封装的很严实,还有他们自己重新做的控件,无法直接使用, 关键的控件也上了锁,可能也是保 ...

  3. js filter关键字

    filter filter也是一个常用的操作,它用于把Array的某些元素过滤掉,然后返回剩下的元素. 和map()类似,Array的filter()也接收一个函数.和map()不同的是,filter ...

  4. Python.Flask.0

    Resource List of Flask 1. 吐槽 Python Web 框架 Flask https://blog.tonyseek.com/post/discuss-about-flask- ...

  5. mysql 5.17 的update失败问题

    在使用workbench的时候,写入update语句,会很提现失败,原因是安全模式; 可能是workbench在数据库更新的时候是有限制的,防止错误哦l 更改方法也很简单; Edit - Profer ...

  6. RavenDb使用

    在Raven中查询数据,查询条件必须在index中. 如果查询条件不在index中就会出现如下异常 var query = session.DynamicIndexQuery<ServicePr ...

  7. Loadrunner 脚本录制策略

    Loadrunner在脚本录制过程中,我们会先后分别碰见init.action.transaction.end.block等概念.本次打算以图文并茂的形式为大家分别讲解. 以下为一个简要的网站操作逻辑 ...

  8. lua 2.2 变种

    1.修改 ~= 操作符为 != 2.取消 --[[ ]] 多行注释语法 下载源码

  9. where_1

    (二)WHERE //where不单独使用,与match,optional match,start,with搭配 where 与match,optional match 一起用,表示约束 where ...

  10. phantomjs问题收集

    1. phantomjs如果遇到重定向的url,两个页面都会加载,onInitialized只会执行一次,onResourceReceived会执行两次.我试过在onInitialized加一段代码, ...