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

8 篇文章 2 订阅
7 篇文章 0 订阅

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
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

one312

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值