又一种获取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是一种开源的内存中数据存储,通常用作数据库,缓存或消息代理.它可以存储和操作高级数据类型,例如列表,地图,集合和排序 ...
随机推荐
- Linux学习笔记-Centos7搭建owncloud私有云盘
使用环境:虚拟机centos7 1.下载安装LAMP相关软件 [root@localhost yum.repos.d]# yum install httpd –y [root@localhost yu ...
- linux运维基础知识-系统分区及LVM逻辑卷的创建
系统分区及LVM逻辑卷的创建 分区 创建逻辑卷 LVM简介:逻辑卷管理器(LogicalVolumeManager)本质上是一个虚拟设备驱动,是在内核中块设备和物理设备之间添加的一个新的抽象层次,如图 ...
- pico g2 触摸板手柄射线检测---for unity
1.pico g2手柄射线检测UI,需要在canvas添加Graphic Raycaster脚本和Pvr_Ui Canvas脚本. 2.删除掉原有的maincamera,将Pvr_unitySDK下h ...
- 最简单的基于FFMPEG+SDL的视频播放器:拆分-解码器和播放器
===================================================== 最简单的基于FFmpeg的视频播放器系列文章列表: 100行代码实现最简单的基于FFMPEG ...
- LeetCode227:基本计算器II
感觉自己的思路还不错,比较简单清晰,代码量也比较少,没有用到记录运算符的变量或栈,就想把这个思路发一下博客. 题目: 实现一个基本的计算器来计算一个简单的字符串表达式的值. 字符串表达式仅包含非负整数 ...
- HDU_5230_DP
http://acm.hdu.edu.cn/showproblem.php?pid=5230 有初始值c,给你1~n的数,输入c+一些数,使得结果在l~r的范围内,输出方案数,注意每种方案中每个数只能 ...
- error C2338: No Q_OBJECT in the class with the signal (NodeCreator.cpp)
在Qt中,当派生类需要用到信号与槽机制时,有两个要求. 1.该类派生自QObject类. 2.类中有Q_OBJECT宏. 本次报错的原因就是因为没有在类中添加Q_OBJECT宏. 而我的出错原因更傻逼 ...
- [redis读书笔记] 第一部分 数据结构与对象 字典
三 字典 字典是Hash对象的底层实现,比如用HSET创建一个HASH的对象,底层可能就是用一个字典实现的键值对. 字典的实现主要设计下面三个结构: /* * 哈希表节点 */ typedef str ...
- 踩坑ThinkPHP5之模型对象返回的数据集如何转为数组
各位小伙伴们大家好,冷月今天在做项目的过程中呢,遇到了一个坑就是用tp5的模型操作数据库时,返回的是数据集而不是直接的数组.于是冷月就想办法如何将数据集转为数组.写下这篇博文,防止大家遇到这个坑时可以 ...
- 开源堡垒机jumpserver的配置和使用
开源跳板机jumpserver配置和使用 http://docs.jumpserver.org/zh/docs/quick_start.html#id9 系统设置 基本设置 # 修改url 的&quo ...