微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何使用主终端节点和读取器终端节点连接到 AWS ElastiCache

如何解决如何使用主终端节点和读取器终端节点连接到 AWS ElastiCache

我的应用程序使用 AWSElastiCache 进行会话存储。创建了一个具有 1 个主节点和 2 个副本节点的 redis 实例(集群模式已禁用)。我正在使用 Lettuce 作为 Redis 客户端,它是 Spring Boot 内部用于连接 Redis 的。我正在使用 AWSElastiCache 的主要和读取器端点进行 redis,以根据 AWS 建议创建 redis 连接。

https://aws.amazon.com/about-aws/whats-new/2019/06/amazon-elasticache-launches-reader-endpoint-for-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建立连接以有效利用集群中的所有副本节点进行读取操作的推荐方法是什么。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。