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启动日志发现
在这里插入图片描述

719522:S 23 Aug 2024 15:09:54.886 * (Non critical) Master does not understand REPLCONF listening-port: -NOAUTH Authentication required.
719522:S 23 Aug 2024 15:09:54.889 * (Non critical) Master does not understand REPLCONF capa: -NOAUTH Authentication required.

上述提示说进行集群同步时需要使用认证(因为每个redis节点都配置了密码),由此可以看出从节点(slave)连接主节点(master)时,没有找到正确密码,导致主从之间数据同步机制建立失败。

问题解决

在每个redis的配置文件(redis.conf)中找到了属性masterauth ,默认是注释状态,打开对应的配置然后配置上我们设置的密码123456 然后重启redis

在这里插入图片描述

问题未及时发现原因

redis集群启动后

  1. 没有去查看每一个redis 节点信息(info),能够看到master节点connected_slaves:1 则正常
  2. 没有去及时查看redis启动日志
  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值