汕尾海湾 发表于 4 天前

Spring Boot 2.x 到 3.x 迁移实战:Redis 配置篇

媒介

随着 Spring Boot 3.x 的发布,其对 Java 17 的支持和 模块化架构 的深化,Redis 配置与集成方式发生了明显变化。今天简单讲下redis的变化
一、Redis 配置前缀的模块化演进:从 spring.redis 到 spring.data.redis

1.1 Spring Boot 2.x(Java 8)



[*]配置前缀:spring.redis
[*]示例:spring:
redis:
    host: localhost
    port: 6379
    password: mypassword
    timeout: 2000
    lettuce:
      pool:
      max-active: 8
      max-idle: 8

[*]特点:直接通过 spring.redis 配置 Redis 连接参数,未明白与 Spring Data 模块绑定。
1.2 Spring Boot 3.x(Java 17)



[*]配置前缀:spring.data.redis
[*]示例:spring:
data:
    redis:
      host: localhost
      port: 6379
      password: mypassword
      timeout: 2000ms
      client:
      type: lettuce
      lettuce:
          pool:
            max-active: 8

[*]模块化筹划:遵照 Spring Data Commons 的统一定名规则,与 spring.data.mongodb 等其他数据源保持同等,便于扩展和维护。
二、Redis 客户端库的颠覆性变化:Lettuce 一统天下

2.1 Spring Boot 2.x:Jedis 和 Lettuce 并存



[*]支持客户端:

[*]Jedis:基于壅闭式 I/O,得当简单场景。
[*]Lettuce:基于 Netty 的非壅闭式,支持异步操作和响应式流(Reactive Streams)。

[*]配置示例:spring:
redis:
    client-type: jedis# 或 lettuce
    jedis:
      pool:
      max-active: 8
    lettuce:
      pool:
      max-active: 8

2.2 Spring Boot 3.x:Lettuce 独占



[*]官方声明:

[*]Jedis 客户端被弃用,仅支持 Lettuce。
[*]缘故起因:Lettuce 的非壅闭特性更契合现代高并发场景,且与 Spring Reactor 生态深度集成。

[*]配置示例:spring:
data:
    redis:
      client-type: lettuce
      lettuce:
      pool:
          max-active: 8
          max-wait: 1000ms

[*]迁移建议:<!-- 移除 Jedis 相关依赖 -->
<!-- 保留 Lettuce 依赖 -->
<dependency>
    <groupId>io.lettuce</groupId>
    <artifactId>lettuce-core</artifactId>
</dependency>

三、RedisTemplate 的序列化策略升级:从 Java 序列化到 JSON

3.1 Spring Boot 2.x



[*]默认序列化器:JdkSerializationRedisSerializer(基于 Java 序列化)。
[*]题目:

[*]序列化后键值对难以直接读取(如 "\xac\xed\x00...")。
[*]跨语言兼容性差,且存在性能消耗。

3.2 Spring Boot 3.x



[*]默认序列化器:GenericJackson2JsonRedisSerializer(基于 JSON)。
[*]优势:

[*]键值对以 JSON 格式存储,可读性高。
[*]跨语言兼容性好,得当微服务场景。

[*]配置示例(若需规复旧行为):@Configuration
public class RedisConfig {
    @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
      RedisTemplate<String, Object> template = new RedisTemplate<>();
      template.setKeySerializer(new StringRedisSerializer());
      template.setValueSerializer(new JdkSerializationRedisSerializer());
      template.setConnectionFactory(factory);
      return template;
    }
}

四、集群与哨兵模式的配置迁移

4.1 Spring Boot 2.x

spring:
redis:
    cluster:
      nodes: localhost:7000,localhost:7001
    sentinel:
      master: master1
      nodes: localhost:26379
4.2 Spring Boot 3.x

spring:
data:
    redis:
      cluster:
      nodes: localhost:7000,localhost:7001
      sentinel:
      master: master1
      nodes: localhost:26379
五、连接池与超时参数的规范化

5.1 Spring Boot 2.x

spring:
redis:
    lettuce:
      pool:
      max-active: 8
      max-idle: 8
      min-idle: 0
      max-wait: -1
      read-timeout: 1000
5.2 Spring Boot 3.x

spring:
data:
    redis:
      lettuce:
      pool:
          max-active: 8
          max-idle: 8
          min-idle: 0
          max-wait: -1ms
      read-timeout: 1000ms


[*]关键变化:

[*]超时参数需显式指定单位(如 ms)。
[*]max-wait 改为 max-wait-time(部分版本大概不同,需参考文档)。

六、Redisson 集成的路径调解

6.1 Spring Boot 2.x

spring:
redis:
    redisson:
      config: |
      singleServerConfig:
          address: redis://localhost:6379
6.2 Spring Boot 3.x

spring:
data:
    redis:
      redisson:
      config: |
          singleServerConfig:
            address: redis://localhost:6379
七、安全性配置:SSL/TLS 的统一路径

7.1 Spring Boot 3.x

spring:
data:
    redis:
      ssl: true
      ssl-trust-store: classpath:truststore.jks
      ssl-trust-store-password: mypassword
      ssl-trust-store-type: JKS
八、迁移策略与最佳实践

8.1 配置文件迁移步调


[*]替换前缀:

[*]将 spring.redis 改为 spring.data.redis。

[*]移除 Jedis 配置:

[*]删除 jedis.pool 相关参数。

[*]查抄超时单位:

[*]为 timeout、read-timeout 等参数添加 ms 后缀。

8.2 依赖管理

<!-- Spring Boot 3.x 依赖 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<dependency>
    <groupId>io.lettuce</groupId>
    <artifactId>lettuce-core</artifactId>
    <version>6.2.4.RELEASE</version> <!-- 保持最新版本 -->
</dependency>
8.3 测试与验证

@SpringBootTest
@AutoConfigureCache
public class RedisConfigTest {

    @Autowired
    private RedisTemplate<String, String> redisTemplate;

    @Test
    public void testRedisConnection() {
      redisTemplate.opsForValue().set("testKey", "testValue");
      assertEquals("testValue", redisTemplate.opsForValue().get("testKey"));
    }
}
九、性能优化与高级配置

9.1 Lettuce 的异步与响应式支持



[*]异步操作:@Autowired
private ReactiveRedisTemplate<String, String> reactiveTemplate;

public Mono<String> asyncGet(String key) {
    return reactiveTemplate.opsForValue().get(key);
}

[*]响应式流集成:@Autowired
private Flux<String> reactiveKeys() {
    return reactiveTemplate.keys("pattern:*").flatMap(key -> reactiveTemplate.opsForValue().get(key));
}

9.2 高级连接池配置

spring:
data:
    redis:
      lettuce:
      pool:
          max-active: 100
          max-wait: 1000ms
          min-idle: 10
          max-idle: 50
十、总结:模块化筹划的深层价值

Spring Boot 3.x 的配置调解并非简单的语法变化,而是 模块化筹划 的体现:


[*]统一定名空间:通过 spring.data.redis 集中管理 Redis 配置,降低认知成本。
[*]技能演进:镌汰 Jedis,拥抱 Lettuce 的非壅闭特性,提升性能与可维护性。
[*]配置标准化:强制单位标注(如 timeout: 2000ms)镌汰配置歧义。
十一、附录:关键配置对比表

配置项Spring Boot 2.xSpring Boot 3.x客户端类型spring.redis.client-typespring.data.redis.client-type连接池配置spring.redis.poolspring.data.redis.lettuce.poolJSON 序列化需手动配置默认启用SSL 配置spring.redis.sslspring.data.redis.sslRedisson 集成路径spring.redis.redissonspring.data.redis.redisson 十二、进一步阅读



[*]Spring Boot 3.x 迁移指南
[*]Spring Data Redis 文档
[*]Lettuce 官方文档

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: Spring Boot 2.x 到 3.x 迁移实战:Redis 配置篇