Redis集群搭建后,写入的数据通过java代码进行读取读取不到数据问题小记

搭建一个三主三从的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集群启动后

  1. 没有去查看每一个redis 节点信息(info),能够看到master节点connected_slaves:1 则正常
  2. 没有去及时查看redis启动日志

原文链接:https://blog.csdn.net/qq_40270466/article/details/141467301

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容