参考链接,这个写的比我的详细很多,也很好理解
我只是搬砖的
搭建集群的方法,这里就不详细说了,对应的启动6个端口就行了,然后集群的配置加上,因为是测试,所以啥备份的日志的都可以不用配置
以下 目前是已经搭建了一个集群了有6个节点3个master,3个slave
我现在要加2个节点 6390 6391, 先启动这两个节点
redis-server 6390.conf
redis-server 6391.conf
将6390节点加入进集群
# 127.0.0.1:6380 这个参数是已知的在集群中的节点
redis-trib.rb add-node 127.0.0.1:6390 127.0.0.1:6380
再看一下集群节点状态,我们可以看到节点已经加进去了,但是还用不了,没有分配哈希槽
开始分配哈希槽
redis-trib.rb reshard 127.0.0.1:6380
第一问你将要分配多少个哈希槽给这个节点,下面有个node id 这个就填6390的id就行
第二问,选择all从原来的那些master拿出点哈希槽,分配到你这个id 6390上,这个差不多是均等分的
可以看到哈希槽已经分过去了,原来那三个master节点的一些哈希槽都相对应的减少了
开始添加 6391 slave从节点
cluster nodes 可以看到这个时候6391 是一个master
我们 redis-cli -c -p 6391 上去改一下,使用 cluster replicate master_id 命令指定master
测试读slave是否OK
节点的删除
删除6390 这个master吧,删除之前先把哈希槽给其他的节点,不然如果有数据是落在这个6390哈希槽上,这时删节点的话数据是有可能会丢失的,所以需要把哈希槽分出去
- redis-trib.rb shrad ip:port 重新分配
- 根据提示进行,1.选择接受数据的节点 2.将要迁移分片的大小(这个必须是准确的,不然后面删除不了节点)3. source 选择源节点,然后done ,yes进行开发reshard
- redis-trib.rb del-node 127.0.0.1:6390 节点的id,
这是第二次reshard,第一次reshard就没截图了,都是一样的操作,我这里第二次reshard是因为第一次没有reshard完
删除节点
cluster nodes 对比原来的nodes可以发现6390这个节点已经没有了,当移除一个节点时该节点的服务也会关掉
可以看到这个时候 6391 的master换成了6380,说明了这个集群是会给门进行这种切换的