Docker配置的Redis集群报错CLUSTERDOWN Hash slot not served的解决办法

redis-cluster 报错 CLUSTERDOWN Hash slot not served 的解决办法

问题示例:

(base) wdh@wdh:~/D/nmpr$ redis-cli -c -h 172.17.0.1 -p 6379
172.17.0.1:6379> set name wdh
(error) CLUSTERDOWN Hash slot not served
172.17.0.1:6379> quit

解决办法:

  • 1.可能是redis节点没有全部加入到到集群中。连接每一个集群节点meet集群。
例如,我的集群节点如下:

cluster:172.17.0.1 6379
master1:172.17.0.1 6391
master2:172.17.0.1 6392
master3:172.17.0.1 6393
slave1:172.17.0.1 6391
slave2:172.17.0.1 6392
slave3:172.17.0.1 6393

那么用reids-cli命令链接redis各节点,并依次meet集群入口6379之后,集群即可恢复正常:

redis-cli -c -h 172.17.0.1 -p 6391
>cluster meet 172.17.0.1 6379
>quit
redis-cli -c -h 172.17.0.1 -p 6392
>cluster meet 172.17.0.1 6379
>quit
redis-cli -c -h 172.17.0.1 -p 6393
>cluster meet 172.17.0.1 6379
>quit
redis-cli -c -h 172.17.0.1 -p 6394
>cluster meet 172.17.0.1 6379
>quit
redis-cli -c -h 172.17.0.1 -p 6395
>cluster meet 172.17.0.1 6379
>quit

执行结果:

(base) wdh@wdh-PC:~$ docker exec -it redis-master1 /bin/bash
root@306117aceb78:/config# redis-cli -c -h 172.17.0.1 -p 6396
172.50.0.1:6396> cluster meet 172.17.0.1 6379
OK
172.50.0.1:6396> quit

root@306117aceb78:/config# redis-cli -c -h 172.17.0.1 -p 6395
172.17.0.1:6395> cluster meet 172.17.0.1 6379
OK
172.17.0.1:6395> quit

root@306117aceb78:/config# redis-cli -c -h 172.17.0.1 -p 6394
172.17.0.1:6394> cluster meet 172.17.0.1 6379
OK
172.17.0.1:6394> quit

root@306117aceb78:/config# redis-cli -c -h 172.17.0.1 -p 6393 
172.17.0.1:6393> cluster meet 172.17.0.1 6379
OK
172.17.0.1:6393> quit

root@306117aceb78:/config# redis-cli -c -h 172.17.0.1 -p 6392
172.17.0.1:6392> cluster meet 172.17.0.1 6379
OK
172.17.0.1:6392> quit

root@306117aceb78:/config# redis-cli -c -h 172.17.0.1 -p 6391
172.17.0.1:6391> cluster meet 172.17.0.1 6379
OK
172.17.0.1:6391> 
  • 其他方法参考(我没有验证这些方法是否可行):
标题:redis-cluster遇到CLUSTERDOWN Hash slot not served问题
地址:https://www.jianshu.com/p/e519471d530b
标题:解决 (error) CLUSTERDOWN Hash slot not served
地址:https://blog.csdn.net/u010235716/article/details/99645657
标题:(error) CLUSTERDOWN Hash slot not served
地址:https://blog.csdn.net/u012060033/article/details/78553124
标题:redis集群报错:(error) CLUSTERDOWN Hash slot not served
地址:https://www.cnblogs.com/hanguoqing/p/10411128.html

测试是否已解决:


# 连接一个redis节点(我这里连接了master1),执行:redis-cli -c -h 172.17.0.1 -p 6392 然后设置一个数据:set name wdh

root@306117aceb78:/config# redis-cli -c -h 172.17.0.1 -p 6392
172.17.0.1:6392> set name wdh
OK
172.17.0.1:6392> 

# 连接另一个 redis节点,执行:redis-cli -c -h 172.17.0.1 -p 6396 然后读取第一个节点设置的数据:get name wdh

root@306117aceb78:/config# redis-cli -c -h 172.17.0.1 -p 6396
172.17.0.1:6396> get name
-> Redirected to slot [5798] located at 172.50.0.1:6392
"wdh"
172.50.0.1:6392>


# 然后redis连接集群(172.17.0.1 6379):redis-cli -c -h 172.17.0.1 -p 6379,然后测试读取集群读写在节点中的设置的数据

(base) wdh@wdh-PC:~/nmpr/redis$ redis-cli -c -h 172.17.0.1 -p 6379
172.100.0.3:6392> get name
"wdh"
172.100.0.3:6392> 
# 成功读到节点中的数据

# 测试写入数据:

172.100.0.3:6392> set sex 1
-> Redirected to slot [2584] located at 172.100.0.1:6391
OK
172.100.0.1:6391>

# 测试去单个节点读取:

root@306117aceb78:/config# redis-cli -c -h 172.17.0.1 -p 6394
172.17.0.1:6394> get sex
-> Redirected to slot [2584] located at 172.50.0.1:6391
"1"
172.50.0.1:6391> 

# 以上结果证明一切都 OK
发布了118 篇原创文章 · 获赞 17 · 访问量 7万+

猜你喜欢

转载自blog.csdn.net/one312/article/details/104983140