我的应用程序使用 AWSElastiCache 进行会话存储。创建了一个具有 1 个主节点和 2 个副本节点的 redis 实例(已禁用集群模式)。我使用 Lettuce 作为 Spring Boot 内部的 Redis 客户端来连接 Redis。我正在使用 AWSElastiCache 的主要和读取器端点用于 redis,以根据 AWS 建议创建 redis 连接。
这是我创建连接工厂的 Bean
@Bean
public LettuceConnectionFactory redisConnectionFactory(){
LettuceClientConfiguration clientConfig = LettuceClientConfiguration.builder()
.readFrom(ReadFrom.REPLICA_PREFERRED)
.useSsl()
.build();
RedisStaticMasterReplicaConfiguration redisStaticMasterReplicaConfiguration = new
RedisStaticMasterReplicaConfiguration(primaryEndPoint,6379);
redisStaticMasterReplicaConfiguration.addNode(readerEndPoint, 6379);
redisStaticMasterReplicaConfiguration.setPassword(redisPassword);
return new LettuceConnectionFactory(redisStaticMasterReplicaConfiguration, clientConfig);
}
看起来阅读器端点没有将读取流量平均分配到所有副本节点。通过查看 Cloud watch 指标,我看到一个副本节点的 CacheHits 为 0,并且似乎所有读取请求都由两个副本节点中的一个副本节点提供服务。与 Redis 建立连接以有效利用集群中的所有副本节点进行读取操作的推荐方法是什么。