搭建一个三主三从的redis集群,所有redis都启动后,然后使用命令行创建集群,命令行如下所示,-a 是指定了密码(在redis配置文件中启用了密码连接)
./redis-cli --cluster create 192.168.0.10:6479 192.168.0.10:6579 192.168.0.10:6679 192.168.0.10:6779 192.168.0.10:6879 192.168.0.10:6979 --cluster-replicas 1 -a 123456
集群创建完成后直接使用命令行测试数据的读写,发现读写正常,没有出现问题(原因是读写只在master节点上进行了,从节点读取数据没有测试,所以没有及时发现集群问题)
然后使用Redisson客户端去连接redis集群然后进行数据的读写发现,能够写入进去数据,但是进行读取时返回null,去判断key是否存在时返回的也是false。
问题发现
通过查看每个redis节点的日志,以及通过redis-cli 的info命令查看节点信息时发现问题;下图中的显示的connected_slaves 值为1是正确,异常情况显示的为值为0
上述提示说进行集群同步时需要使用认证(因为每个redis节点都配置了密码),由此可以看出从节点(slave)连接主节点(master)时,没有找到正确密码,导致主从之间数据同步机制建立失败。
问题解决
在每个redis的配置文件(redis.conf)中找到了属性masterauth ,默认是注释状态,打开对应的配置然后配置上我们设置的密码123456 然后重启redis
问题未及时发现原因
redis集群启动后
- 没有去查看每一个redis 节点信息(info),能够看到master节点connected_slaves:1 则正常
- 没有去及时查看redis启动日志
原文链接:https://blog.csdn.net/qq_40270466/article/details/141467301
网友评论