又一种获取redis cluster slots分布的小脚本
需要:昨晚学习了cluster slots命令,之前写的脚本,有可以换种方法获取到redis cluster slots 分布情况。
cluster slots的结果如下:
4
5460
5.5.5.102
29001
eb7dfedad330c2421ed04321ca24c33ebcadb1a9
5.5.5.101
29001
6ecf0faaedafcf2e4b14c221721d3b279f2c5748
1
3
5.5.5.101
29003
7c79008aac1a2b1aa3f64e9d3747146f766386bd
5.5.5.103
29003
a3f384efcd3e38642b5fb68507fde01a5117704f
10923
16383
5.5.5.101
29003
7c79008aac1a2b1aa3f64e9d3747146f766386bd
5.5.5.103
29003
a3f384efcd3e38642b5fb68507fde01a5117704f
0
0
5.5.5.103
29002
a76debe07f1b481a4ac634d3bfaac782c0cb2024
5.5.5.102
29002
2da5169ef3cf069a5088eb4c84363e2bea34fbba
5461
10922
5.5.5.103
29002
a76debe07f1b481a4ac634d3bfaac782c0cb2024
5.5.5.102
29002
2da5169ef3cf069a5088eb4c84363e2bea34fbba
获取redis cluster slots分布的小脚本
redis-cli -h $1 -p $2 -c cluster slots | xargs -n8 | awk '{print $3":"$4" "$1"-"$2}' > tmp_slot_range
awk '{a[$1]++}END{for(i in a)print i}' tmp_slot_range | sort -nk2 -t ":" > ip_port
for i in `cat ip_port`
do
slots=($(awk '/'$i'/{print $2}' tmp_slot_range))
len=${#slots[@]}
printf "$i-> "
for(( j=0;j<=len-1;j++))
do
printf "${slots[j]} "
done
echo
done
脚本说明:
第1行获取到结果如下:
5.5.5.102:29001 4-5460
5.5.5.101:29003 1-3
5.5.5.101:29003 10923-16383
5.5.5.103:29002 0-0
5.5.5.103:29002 5461-10922
第2行获取的结果如下:
5.5.5.102:29001
5.5.5.103:29002
5.5.5.101:29003
第4-14行获取第2行的结果的每一行对应的slot范围
测试结果
[redis@lxd-vm1 ~]$ sh a8.sh 5.5.5.101 29001
5.5.5.102:29001-> 4-5460
5.5.5.103:29002-> 0-0 5461-10922
5.5.5.101:29003-> 1-3 10923-16383
[redis@lxd-vm1 ~]$
之前迁移了一个slot到其他节点,这里再优化一下输出的结果,将单个slot的情况,如0-0 输出为0
redis-cli -h $1 -p $2 -c cluster slots | xargs -n8 | awk '{print $3":"$4" "$1"-"$2}' > tmp_slot_range
awk '{a[$1]++}END{for(i in a)print i}' tmp_slot_range | sort -nk2 -t ":" > ip_port
for i in `cat ip_port`
do
slots=($(awk '/'$i'/{print $2}' tmp_slot_range))
len=${#slots[@]}
printf "$i-> "
for(( j=0;j<=len-1;j++))
do
s1=$(echo ${slots[j]} | awk -F[-] '{print $1}')
s2=$(echo ${slots[j]} | awk -F[-] '{print $2}')
if [[ $s1 -eq $s2 ]];then
printf "$s1 "
else
printf "${slots[j]} "
fi
done
echo
done
测试结果:
[redis@lxd-vm1 ~]$ sh a8.sh 5.5.5.101 29001
5.5.5.102:29001-> 4-5460
5.5.5.103:29002-> 0 5461-10922
5.5.5.101:29003-> 1-3 10923-16383
[redis@lxd-vm1 ~]$
又一种获取redis cluster slots分布的小脚本的更多相关文章
- 另外一种获取redis cluster主从关系和slot分布的方法
条条大路通罗马,通过最近学习redis cluster 观察其输出,发现了另外一种获取master-slave关系的方法. [redis@lxd-vm1 ~]$ cat get_master_slav ...
- 第3种方法获取redis cluster主从关系
需求:使用cluster slots命令,获取redis cluster 主从对应关系. 说明:cluster slots命令对应的字段说明:http://redis.cn/commands/clus ...
- 获取redis cluster中所有节点的内存使用情况
需求:获取redis cluster集群中所有节点的内存使用情况. ip_port=`redis-cli -h $ -p $ -a abc123 -c cluster nodes | awk '{pr ...
- 直观获取redis cluster 主从关系
需求:还是redis-trib.rb脚本获取的信息不足或者太繁杂,这里给出更加直观的一种方法, 说明:已在4.x版本测试通过,3.x不可用. 原生的输出 (1adfa7f3...) keys slot ...
- redis cluster slots数量 为何是16384(2的14次方)
Redis 集群并没有使用一致性hash,而是引入了哈希槽的概念. Redis 集群有16384个哈希槽,每个key通过CRC16校验后对16384取模来决定放置哪个槽,集群的每个节点负责一部分has ...
- 获取redis cluster master对应的slot分布情况
需求:原生的redis-trib.rb功能是强大,但输出的内容过于繁杂,比如我需要关注哪些master对应哪些slots,不是很直观,如果集群的规模更大的话,那么输出的结果获取信息更加困难. 说明:这 ...
- 获取本机IP地址的小脚本
获取本机私网地址(1个) #!/bin/bash # Author : standby # Date : -- # Description : Get private ip address of lo ...
- K8S部署Redis Cluster集群
kubernetes部署单节点redis: https://www.cnblogs.com/zisefeizhu/p/14282299.html Redis 介绍 • Redis代表REmote DI ...
- K8S部署Redis Cluster集群(三主三从模式) - 部署笔记
一.Redis 介绍 Redis代表REmote DIctionary Server是一种开源的内存中数据存储,通常用作数据库,缓存或消息代理.它可以存储和操作高级数据类型,例如列表,地图,集合和排序 ...
随机推荐
- maven jar 包问题
1. Failure to transfer... 这种错误基本是所需要的 jar 包不存在,或者下载不完整,可去本地仓库查看相关 jar 文件的完整性 解决方案: 删除对应 jar 包,重新下载(删 ...
- 源码级别gdb远程调试(实现OS简单内核)
最近在学着编写一个操作系统的简单内核,需要debug工具,我们这里使用gdb来进行调试,由于虚拟机运行和本机是两个部分,所以使用 gdb 的远程调试技术,这里对 gdb 常见调试以及远程调试方式做一个 ...
- 五大常见算法策略之——动态规划策略(Dynamic Programming)
Dynamic Programming Dynamic Programming是五大常用算法策略之一,简称DP,译作中文是"动态规划",可就是这个听起来高大上的翻译坑苦了无数人 ...
- Python 语言规范(Google)
Python语言规范 Lint tip 对你的代码运行pylint 定义: pylint是一个在Python源代码中查找bug的工具. 对于C和C++这样的不那么动态的(译者注: 原文是less dy ...
- WeChall_Training: PHP LFI (Exploit, PHP, Training)
Your mission is to exploit this code, which has obviously an LFI vulnerability: GeSHi`ed PHP code 1 ...
- EMC NW NMM to restore MS AG database
Following last article, how to restore MS AG database , that is in the following: You see ? Cheer u ...
- 一口气说出Redis 5种数据结构及对应使用场景,面试要加分的
整理了一些Java方面的架构.面试资料(微服务.集群.分布式.中间件等),有需要的小伙伴可以关注公众号[程序员内点事],无套路自行领取 更多优选 一口气说出 9种 分布式ID生成方式,面试官有点懵了 ...
- 【WPF学习】第四十四章 图画
通过上一章的学习,Geometry抽象类表示形状或路径.Drawing抽象类扮演了互补的角色,它表示2D图画(Drawing)——换句话说,它包含了显示矢量图像或位图需要的所有信息. 尽管有几类画图类 ...
- num05---装饰模式
当系统需要新的功能的时候,一般都是向旧的类中添加新的代码.比如一个人这个类,需要新增穿衣的功能,那么就会在人这个类中去添加对应的穿衣方法代码,用来增强人这个类的行为功能.但是这样做,会因为新加入的字段 ...
- 超长可视化指南!带你理清K8S部署的故障排查思路,让bug无处遁形
本文将帮助你厘清在Kubernetes中调试 deployment的思路.下图是完整的故障排查思路,如果你想获得更清晰的图片,请在公众号后台(RancherLabs)回复"troublesh ...