redis:ERR CLUSTER RESET can't be called with master nodes containing keys

        我们在建立Redis集群的时候,当集群已经启动完成后,这个时候我们通过命令./src/redis-cli --cluster add-node newip:newport oldip:oldport新增节点的时候,这个时候会自动添加为一个master节点,但是有可能在这个添加过程中oldip:oldport会出现连接不上的错误,但是新的节点也添加成功了,我们通过./src/redis-cli --cluster check ip:port的方式查看这个newip:newport又没有成为集群的节点,当我们又重新通过./src/redis-cli --cluster add-node newip:newport oldip:oldport命令进行集群添加的时候可能就会出现下面的错误

[ERR] Node 172.168.52.157:6363 is not empty. Either the node already knows other nodes (check with CLUSTER NODES) or contains some key in database 0.

我们通过命令 ./src/redis-cli  -p 6363进入后

127.0.0.1:6363> cluster nodes
975180c43dc29b2b0ec4f7fbb5433a04291d7999 :6363@16363 myself,master - 0 0 0 connected 8740
127.0.0.1:6363> keys *
1) "map1"

      发现因为是master,所以connected 8740代表了一个hash slots是8740的槽位,并且还有一个key值map1,所以这个是错误的,这个时候我们需要通过命令行flushall的方式

[root@web-server01 redis-5.0.5]$ ./src/redis-cli -p 6359
127.0.0.1:6359> flushall 

或者在conf配置文件的cluster-config-file配置的文件路径下的xxx.conf文件和dump.rdb文件即可,清空掉文件后我们就可以通过在命令行中用cluster reset的方式重置hash slots

127.0.0.1:6359> cluster reset

重置完成后就可以进行后续的添加操作了。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值