查看Redis集群主从对应关系工具

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
云原生内存数据库 Tair,内存型 2GB
云数据库 Redis 版,经济版 1GB 1个月
简介: 工具的作用: 1)比“cluster nodes”更为直观的显示结果 2)指出落在同一个IP上的master 3)指出落在同一个IP上的master和slave对 运行效果图: 源代码(可从https://github.

工具的作用:

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

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

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


运行效果图:



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

点击(此处)折叠或打开

  1. #!/bin/bash
  2. # 源码位置:https://github.com/eyjian/redis-tools
  3. #
  4. # Redis集群部署注意事项:
  5. # 在一个物理IP上部署多个redis实例时,要避免:
  6. # 1) 一对master和slave出现在同一物理IP上(影响:物理机挂掉,部分keys彻底不可用)
  7. # 2) 同一物理IP上出现多个master(影响:物理机挂掉,将导致两对切换)
  8. #
  9. # 使用示例(带一个参数):
  10. # show_redis_map.sh 192.168.0.21:6380
  11. #
  12. # 检查Redis集群master和slave映射关系的命令行工具:
  13. # 1) 查看是否多master出现在同一IP;
  14. # 2) 查看一对master和slave出现在同一IP。
  15. #
  16. # 当同一IP出现二个或多个master,则相应的行标星显示,
  17. # 如果一对master和slave出现在同一IP上,则相应的行标星显示。
  18. #
  19. # 输出效果:
  20. # [01][MASTER] 192.168.0.21:6379 00cc3f37d938ee8ba672bc77b71d8e0a3881a98b
  21. # [02][MASTER] 192.168.0.22:6379 1115713e3c311166207f3a9f1445b4e32a9202d7
  22. # [03][MASTER] 192.168.0.23:6379 5cb6946f46ccdf543e5a1efada6806f3df72b727
  23. # [04][MASTER] 192.168.0.24:6379 b91b1309b05f0dcc1e3a2a9521b8c00702999744
  24. # [05][MASTER] 192.168.0.25:6379 00a1ba8e5cb940ba4171e0f4415b91cea96977bc
  25. # [06][MASTER] 192.168.0.26:6379 64facb201cc5c7d8cdccb5fa211af5e1a04a9786
  26. # [07][MASTER] 192.168.0.27:6379 f119780359c0e43d19592db01675df2f776181b1
  27. # [08][MASTER] 192.168.0.28:6379 d374e28578967f96dcb75041e30a5a1e23693e56
  28. # [09][MASTER] 192.168.0.29:6380 a153d2071251657004dbe77abd10e2de7f0a209a
  29. #
  30. # [01][SLAVE=>MASTER] 192.168.0.21:6380 => 192.168.0.28:6379
  31. # [02][SLAVE=>MASTER] 192.168.0.22:6380 => 192.168.0.25:6379
  32. # [03][SLAVE=>MASTER] 192.168.0.23:6380 => 192.168.0.24:6379
  33. # [04][SLAVE=>MASTER] 192.168.0.24:6380 => 192.168.0.23:6379
  34. # [05][SLAVE=>MASTER] 192.168.0.25:6380 => 192.168.0.22:6379
  35. # [06][SLAVE=>MASTER] 192.168.0.26:6380 => 192.168.0.27:6379
  36. # [07][SLAVE=>MASTER] 192.168.0.27:6380 => 192.168.0.29:6380
  37. # [08][SLAVE=>MASTER] 192.168.0.28:6380 => 192.168.0.21:6379
  38. # [09][SLAVE=>MASTER] 192.168.0.29:6379 => 192.168.0.26:6379
  39. REDIS_CLI=${REDIS_CLI:-redis-cli}
  40. REDIS_IP=${REDIS_IP:-127.0.0.1}
  41. REDIS_PORT=${REDIS_PORT:-6379}
  42. function usage()
  43. {
  44. echo "usage: `basename $0` redis_node"
  45. echo "example: `basename $0` 127.0.0.1:6379"
  46. }
  47. # with a parameter: single redis node
  48. if test $# -ne 1; then
  49. usage
  50. exit 1
  51. fi
  52. # 检查参数
  53. eval $(echo "$1" | awk -F[\:] '{ printf("REDIS_IP=%s\nREDIS_PORT=%s\n",$1,$2) }')
  54. if test -z "$REDIS_IP" -o -z "$REDIS_PORT"; then
  55. echo "parameter error"
  56. usage
  57. exit 1
  58. fi
  59. # 确保redis-cli可用
  60. which "$REDIS_CLI" > /dev/null 2>&1
  61. if test $? -ne 0; then
  62. echo -e "\`redis-cli\` not exists or not executable"
  63. exit 1
  64. fi
  65. # master映射表,key为master的id,value为master的“ip:port”
  66. declare -A master_map=()
  67. # slave映表,key为master的id,value为slave的“ip:port”
  68. declare -A slave_map=()
  69. master_nodes_str=
  70. master_slave_maps_str=
  71. # 找出所有master
  72. masters=`$REDIS_CLI -h $REDIS_IP -p $REDIS_PORT CLUSTER NODES | awk -F[\ \@] '/master/{ printf("%s,%s\n",$1,$2); }' | sort`
  73. for master in $masters;
  74. do
  75. eval $(echo $master | awk -F[,] '{ printf("master_id=%s\nmaster_node=%s\n",$1,$2); }')
  76. master_map[$master_id]=$master_node
  77. if test -z "$master_nodes_str"; then
  78. master_nodes_str="$master_node|$master_id"
  79. else
  80. master_nodes_str="$master_node|$master_id,$master_nodes_str"
  81. fi
  82. done
  83. # 找出所有slave
  84. # “CLUSTER NODES”命令的输出格式当前有两个版本,需要awk需要根据NF的值做区分
  85. 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`
  86. for slave in $slaves;
  87. do
  88. eval $(echo $slave | awk -F[,] '{ printf("master_id=%s\nslave_node=%s\n",$1,$2); }')
  89. slave_map[$master_id]=$slave_node
  90. done
  91. for key in ${!master_map[@]}
  92. do
  93. master_node=${master_map[$key]}
  94. slave_node=${slave_map[$key]}
  95. if test -z "$master_slave_maps_str"; then
  96. master_slave_maps_str="$slave_node|$master_node"
  97. else
  98. master_slave_maps_str="$slave_node|$master_node,$master_slave_maps_str"
  99. fi
  100. done
  101. # 显示所有master
  102. index=1
  103. old_master_node_ip=
  104. master_nodes_str=`echo "$master_nodes_str" | tr ',' '\n' | sort`
  105. for master_node_str in $master_nodes_str;
  106. do
  107. eval $(echo "$master_node_str" | awk -F[\|] '{ printf("master_node=%s\nmaster_id=%s\n", $1, $2); }')
  108. eval $(echo "$master_node" | awk -F[\:] '{ printf("master_node_ip=%s\nmaster_node_port=%s\n", $1, $2); }')
  109. tag=
  110. # 同一IP上出现多个master,标星
  111. if test "$master_node_ip" = "$old_master_node_ip"; then
  112. tag=" (*)"
  113. fi
  114. printf "[%02d][MASTER] %-20s \033[0;32;31m%s\033[m%s\n" $index "$master_node" "$master_id" "$tag"
  115. old_master_node_ip=$master_node_ip
  116. index=$((++index))
  117. done
  118. # 显示所有slave到master的映射
  119. index=1
  120. echo ""
  121. master_slave_maps_str=`echo "$master_slave_maps_str" | tr ',' '\n' | sort`
  122. for master_slave_map_str in $master_slave_maps_str;
  123. do
  124. eval $(echo "$master_slave_map_str" | awk -F[\|] '{ printf("slave_node=%s\nmaster_node=%s\n", $1, $2); }')
  125. eval $(echo "$slave_node" | awk -F[\:] '{ printf("slave_node_ip=%s\nslave_node_port=%s\n", $1, $2); }')
  126. eval $(echo "$master_node" | awk -F[\:] '{ printf("master_node_ip=%s\nmaster_node_port=%s\n", $1, $2); }')
  127. tag=
  128. # 一对master和slave出现在同一IP,标星
  129. if test ! -z "$slave_node_ip" -a "$slave_node_ip" = "$master_node_ip"; then
  130. tag=" (*)"
  131. fi
  132. n=$(($index % 2))
  133. if test $n -eq 0; then
  134. printf "[%02d][SLAVE=>MASTER] \033[1;33m%21s\033[m => \033[1;33m%s\033[m%s\n" $index $slave_node $master_node "$tag"
  135. else
  136. printf "[%02d][SLAVE=>MASTER] %21s => %s%s\n" $index $slave_node $master_node "$tag"
  137. fi
  138. index=$((++index))
  139. done
  140. echo ""


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
18天前
|
存储 运维 NoSQL
Redis Cluster集群模式部署
Redis Cluster集群模式部署
46 4
|
18天前
|
缓存 运维 NoSQL
Redis主从模式部署
Redis主从模式部署
37 4
|
20天前
|
监控 NoSQL 算法
手把手教你如何搭建redis集群(二)
手把手教你如何搭建redis集群(二)
37 1
|
9天前
|
缓存 NoSQL Redis
Redis主从架构
当看到图示中红色标记的,就代表从节点挂载成功了。
12 0
|
6天前
|
缓存 负载均衡 NoSQL
Redis系列学习文章分享---第十四篇(Redis多级缓存--封装Http请求+向tomcat发送http请求+根据商品id对tomcat集群负载均衡)
Redis系列学习文章分享---第十四篇(Redis多级缓存--封装Http请求+向tomcat发送http请求+根据商品id对tomcat集群负载均衡)
16 1
|
13天前
|
NoSQL Redis
redis集群教程
redis集群教程
|
10天前
|
NoSQL Java 关系型数据库
考考你Redis主从,就知道有没深入Redis
大家好,我是南哥。一个对Java程序员进阶成长颇有研究的人,今天继续给大家带来新的一篇Java进阶指南。如果是单机版的数据库,像MySQL、Redis,看起来实现并不复杂。只要支持保存一条数据,同时要能够查询出来。但如果是多机版的数据库呢,各个节点的配合联调是比较复杂的过程,看起来就不是那么简单喽。要考你对Redis深不深入理解,问问Redis多机版相关的问题就知道了。我们今天就来指南下Redis主从架构。
考考你Redis主从,就知道有没深入Redis
|
2天前
|
NoSQL Redis 数据库
Redis的GUI工具——Another-Redis-Desktop-Manager连接远程数据库Redis
Redis的GUI工具——Another-Redis-Desktop-Manager连接远程数据库Redis
6 0
|
6天前
|
存储 监控 NoSQL
Redis系列学习文章分享---第十二篇(搭建哨兵集群+RedisTemplate连接哨兵+搭建分片集群+-散列插槽+集群伸缩 +故障转移+RedisTemplate访问分片集群)
Redis系列学习文章分享---第十二篇(搭建哨兵集群+RedisTemplate连接哨兵+搭建分片集群+-散列插槽+集群伸缩 +故障转移+RedisTemplate访问分片集群)
22 0
|
6天前
|
NoSQL Redis
Redis系列学习文章分享---第五篇(Redis实战篇--优惠券秒杀,全局唯一id 添加优惠券 实现秒杀下单 库存超卖问题分析 乐观锁解决超卖 实现一人一单功能 集群下的线程并发安全问题)
Redis系列学习文章分享---第五篇(Redis实战篇--优惠券秒杀,全局唯一id 添加优惠券 实现秒杀下单 库存超卖问题分析 乐观锁解决超卖 实现一人一单功能 集群下的线程并发安全问题)
11 0