节点
与普通模式下节点的区别是它有一个配置是cluster-enabled:yes,即以集群模式启动
meet
节点之间通过meet实现通信
指派槽
复制
每个主节点都有从节点,主从复制。
redis-cli -p 7000 cluster nodes/info查看节点信息(不开启客户端)
redis-server redis-7000.conf
redis-server redis-7001.conf
redis-server redis-7002.conf
redis-server redis-7003.conf
redis-server redis-7004.conf
redis-server redis-7005.conf
redis-cli -p 7000 cluster meet 127.0.0.1 7001
redis-cli -p 7000 cluster meet 127.0.0.1 7002
redis-cli -p 7000 cluster meet 127.0.0.1 7003
redis-cli -p 7000 cluster meet 127.0.0.1 7004
redis-cli -p 7000 cluster meet 127.0.0.1 7005
此时通过redis-cli -p 7000 cluster info
查看任意一个节点得到的信息中,cluster_known_nodes
的值都为6,即集群中6个节点都能互通。
由于分配槽的命令很多且重复,编写脚本如下:
start=$1
end=$2
port=$3
for slot in `seq ${start} ${end}`
do
redis-cli -p ${port} cluster addslots ${slot}
done
运行脚本为7000、7001、7002分配槽:
sh addslots.sh 0 5461 7000
sh addslots.sh 5462 10922 7001
sh addslots.sh 10923 16383 7002
通过redis-cli -p 7000 cluster nodes
查看节点ID(第一列)。
然后
redis-cli -p 从节点端口
cluster replicate 主节点ID
redis-cli -p 7003 cluster replicate d378ca9057747ed4643e9604de048c72b1e37ebc
redis-cli -p 7004 cluster replicate a41a11969445c1b34b1a7f450339be9dfea6dcd7
redis-cli -p 7005 cluster replicate 6e745ee42dc19ea4259d16aa0837bbba483832a9
Redis Cluster提供了Rubby的安装脚本,可以通过Rubby方便地搭建集群,而不需要通过Redis-cli的原生安装方式。
集群伸缩:槽和数据在节点之间的移动
准备新节点
redis-server redis-7006.conf
即开启一个新的redis-server
加入集群
新节点和已创建的集群握手(meet)
迁移槽和数据
通过redis-cli做会很麻烦,一般使用官方的redis-trib迁移。
下线迁移槽
让其他节点忘记被除去的节点
关闭节点
被客户端访问的槽已经迁移到别的节点
被客户端访问的槽正在迁移中
如:JedisCluster
这样在客户端就有了槽和节点的对应信息,就能直接访问目标节点
尝试客观下线
原文:https://www.cnblogs.com/cky-2907183182/p/13252043.html