Spring Boot 3中使用 Lettuce RedisTemplate 连接 Redis 集群

一 背景

最近在Spring Boot3 应用系统开发过程中,使用了官方的spring-boot-starter-data-redis依赖来操作Redis单节点和集群。在操作单节点时,直接使用了RedisTemplate来对节点进行操作。参考了官方案例,非常方便,几行代码实现了Redis单节点操作。在开发测试时偷了个懒,没有搭建集群。当连接地址替换为集群时,发现客户端不能直接操作集群,顿时懵了!查了官网资料,也仅有寥寥几行,网上目前还是大量使用Jedis客户端来连接操作Redis集群,Lettuce相关的资料也极为稀少。查阅 Spring 官方文档和Lettucce官方文档最终找到了解决方案!还好没放弃!

二 解决步骤

2.1 将 Redis 配置注入 RedisTemplate 相关 Bean

在配置类内增加以下内容:

    private RedisProperties redisProperties;

    @Autowired
    public void setRedisProperties(RedisProperties redisProperties) {
   
        this.redisProperties = redisProperties;
    }

    @Bean("lettuce_template")
    public RedisTemplate<String, String> redisTemplate() {
   
        RedisClusterConfiguration redisClusterConfiguration = new RedisClusterConfiguration(redisProperties.getCluster().getNodes());
        redisClusterConfiguration.setPassword(redisProperties.getPassword());
        LettuceConnectionFactory lettuceConnectionFactory = new LettuceConnectionFactory(redisClusterConfiguration);
        lettuceConnectionFactory.afterPropertiesSet();
        RedisTemplate<String, String> template = new RedisTemplate<>();
        template.setConnectionFactory(lettuceConnectionFactory);
        template.afterPropertiesSet();
        return template;
    }

lettuce_template 这个 Bean 就能成功读取配置文件中的 Redis 集群配置信息,包括节点详情和密码。

2.2 application.properties 配置

配置文件内必须确保存在以下配置,以便Bean初始化时可以正确获取。

spring.data.redis.cluster.nodes=172.31.164.149:6001,172.31.164.149:6002,172.31.164.149:6003,172.31.164.149:6004,172.31.164.149:6005,172.31.164.149:6006
spring.data.redis.password=C*x#1a2b

2.3 使用 Bean

将 lettuce_template 注入到相关组件使用,操作与单节点一致。需要注意的是,注入需使用@Qualifier("lettuce_template")指定,以避免冲突。其他使用方法参见官网文档。

三 总结

1、单节点与集群的初始化方式是不一样的,这一点需要牢记,Bean 不能直接套用,官网的 RedisTemplate 是针对单节点的;
2、Bean注入时尽量指定名称,避免冲突。

四 参考文档

1、Redis Cluster
2、Working with Objects through RedisTemplate
3、Lettuce reference documentation

相关推荐

  1. Spring Boot 3使用 Lettuce RedisTemplate 连接 Redis

    2023-12-14 10:16:04       43 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-14 10:16:04       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-14 10:16:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-14 10:16:04       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-14 10:16:04       20 阅读

热门阅读

  1. C++静态成员数据

    2023-12-14 10:16:04       46 阅读
  2. influxdb docker安装

    2023-12-14 10:16:04       45 阅读
  3. C语言经典错误总结(二)

    2023-12-14 10:16:04       36 阅读
  4. CENTOS 安装zookeeper

    2023-12-14 10:16:04       47 阅读
  5. Active Objects设计模式

    2023-12-14 10:16:04       52 阅读
  6. 卷积的计算 - numpy的实现 1

    2023-12-14 10:16:04       38 阅读
  7. 前端HTML

    2023-12-14 10:16:04       37 阅读
  8. 网络安全知识点总结

    2023-12-14 10:16:04       41 阅读