RedisTemplate的序列化配置方式详解

在使用Spring Data Redis的RedisTemplate时,不同的序列化配置和操作方法会影响数据存储的格式和适用场景。以下是对不同配置和使用场景的详细说明:


一、RedisTemplate的序列化配置方式及使用场景

1. 默认配置 JDK序列化(JdkSerializationRedisSerializer)(不推荐)
@Bean
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
    RedisTemplate<String, Object> template = new RedisTemplate<>();
    
    // 连接工厂
    template.setConnectionFactory(factory);
    // 默认使用JdkSerializationRedisSerializer序列化key和value
    return template;
}
  • 特点:将对象序列化为二进制字节流,Redis中存储为二进制数据。
  • 适用场景:需要直接存储Java对象且不关注可读性,仅用于Java应用间的数据共享。
  • 缺点:数据不可读,跨语言兼容性差,不同JVM版本可能不兼容。

2. Key和Value均使用String序列化(StringRedisSerializer)
@Bean
public RedisTemplate<String, String> stringRedisTemplate(RedisConnectionFactory factory) {
    RedisTemplate<String, String> template = new RedisTemplate<>();
    template.setConnectionFactory(factory);
    template.setKeySerializer(RedisSerializer.string());
    template.setValueSerializer(RedisSerializer.string());
    template.afterPropertiesSet();
    return template;
}
  • 特点:所有数据以字符串形式存储,Key和Value均为可读的字符串。
  • 适用场景:处理纯文本数据,如简单的键值对缓存,或与其他语言兼容的场景。
  • 注意:存储对象时需手动序列化为JSON字符串。

3. Key为String,Value为JSON(Jackson2JsonRedisSerializer)(推荐)
**Jackson2JsonRedisSerializer可以自定序列化和反序列化不需要手动解决**
@Bean
public RedisTemplate<String, Object> jsonRedisTemplate(RedisConnectionFactory factory) {
    RedisTemplate<String, Object> template = new RedisTemplate<>();
    template.setConnectionFactory(factory);
    template.setKeySerializer(RedisSerializer.string());
    template.setValueSerializer(new Jackson2JsonRedisSerializer<>(Object.class));
    template.afterPropertiesSet();
    return template;
}
  • 特点:Value以JSON格式存储,Key为字符串,数据可读且兼容性强。
  • 适用场景:存储复杂对象(如DTO、POJO),需跨语言读取或需要人工查看数据的场景。
  • 扩展:可配置ObjectMapper定制JSON序列化规则。

4. Hash结构的序列化配置(推荐)
@Bean
public RedisTemplate<String, Object> hashRedisTemplate(RedisConnectionFactory factory) {
    RedisTemplate<String, Object> template = new RedisTemplate<>();
    template.setConnectionFactory(factory);
    template.setKeySerializer(RedisSerializer.string());
    template.setHashKeySerializer(RedisSerializer.string());
    template.setHashValueSerializer(new Jackson2JsonRedisSerializer<>(Object.class));
    template.afterPropertiesSet();
    return template;
}
  • 特点:Hash的Field和Value可独立配置序列化方式。
  • 适用场景:存储嵌套结构的数据,如用户属性(Hash Key为属性名,Value为JSON对象)。

5. 高性能二进制序列化(如Protostuff)
@Bean
public RedisTemplate<String, byte[]> binaryRedisTemplate(RedisConnectionFactory factory) {
    RedisTemplate<String, byte[]> template = new RedisTemplate<>();
    template.setConnectionFactory(factory);
    template.setKeySerializer(RedisSerializer.string());
    template.setValueSerializer(RedisSerializer.byteArray());
    template.afterPropertiesSet();
    return template;
}
  • 特点:手动使用Protostuff等工具将对象序列化为字节数组,再通过byte[]存储。
  • 适用场景:对性能要求极高,且无需人工查看数据的场景。

推荐配置序列化按照我写得


链接

这篇文章来配置序列化问题
在这里插入图片描述
解释说明: 一般来说Redis存储的内容是键值对形式的数据,然后里面的的形式用字符串形式的也就是说用,然后的形式用json形式,用 Jackson2JsonRedisSerializer可以序列化反序列化不需要手动的去解决序列化问题。如果使用GenericJackson2JsonRedisSerializer去配置序列化问题在redis里面存储的时候里面会有一个@class(指定数据类型比如说一个User类型的实体类)占用空间。

Jackson2JsonRedisSerializer jsonSerializer = new Jackson2JsonRedisSerializer<>(Object.class)(推荐

二、RedisTemplate的数据操作方法及场景

1. 操作不同数据结构
  • ValueOperations:操作字符串类型。
    ValueOperations<String, String> ops = redisTemplate.opsForValue();
    ops.set("key", "value");
    
  • ListOperations:操作列表类型。
    ListOperations<String, String> ops = redisTemplate.opsForList();
    ops.leftPush("listKey", "item");
    
  • SetOperations/HashOperations/ZSetOperations:分别操作集合、哈希、有序集合。

适用场景:根据数据结构选择对应接口,如缓存列表数据使用ListOperations


2. 使用execute执行底层命令
redisTemplate.execute((RedisCallback<Object>) connection -> {
    connection.set("key".getBytes(), "value".getBytes());
    return null;
});
  • 适用场景:需要执行复杂操作或直接访问底层连接时。

3. 事务支持
redisTemplate.execute(new SessionCallback<>() {
    @Override
    public Object execute(RedisOperations operations) {
        operations.multi();
        operations.opsForValue().set("key1", "value1");
        operations.opsForValue().set("key2", "value2");
        return operations.exec();
    }
});
  • 适用场景:需要保证多个操作的原子性。

三、总结

配置/方法特点适用场景
默认JDK序列化二进制存储,兼容Java对象纯Java应用,无需人工查看数据
Key/Value均String纯文本存储,兼容性强简单键值对,跨语言场景
Key为String,Value为JSON可读性好,支持复杂对象存储DTO对象,需人工查看或跨语言读取
Hash结构定制序列化灵活配置Hash的Field和Value序列化嵌套数据结构,如用户属性
高性能二进制序列化手动控制序列化,性能最优高性能场景,如缓存大量数据
数据结构操作方法通过opsForXXX操作不同数据结构根据业务需求选择对应结构,如列表、集合等
execute底层操作直接使用Redis连接执行命令复杂操作或需要底层控制时
事务支持保证多个操作的原子性需要事务支持的场景
<think>嗯,用户想了解如何配置RedisTemplate序列化设置,我需要根据提供的引用内容来整理答案。首先,记得系统级指令里的要求,行内数学公式用$...$,独立公式用$$...$$,但这里可能用不上数学公式,主要是代码和配置说明。用户需要示例及说明,所以得给出具体的配置步骤和代码例子。 首先,引用3提到RedisTemplate默认使用JdkSerializationRedisSerializer,但通常推荐使用JSON序列化,比如Jackson2JsonRedisSerializer。引用4也提到了反序列化时的类型转换问题,可能需要配置类型提示。此外,引用1和2提到了通过@Qualifier来区分不同的RedisTemplate实例,这点可能在配置多个实例时有用,但用户主要问的是序列化配置,所以这部分可能作为扩展或注意事项提到。 接下来,我需要分步骤说明配置过程。第一步是创建配置类,使用@Configuration注解,然后在里面定义RedisTemplate的Bean。这里需要设置key和value的序列化器,比如StringRedisSerializer用于key,Jackson2JsonRedisSerializer用于value。同时,要配置ObjectMapper来支持类型信息,以便反序列化时能正确转换类型,如引用4提到的例子。 然后,给出代码示例,展示如何配置RedisTemplate。需要注意GenericJackson2JsonRedisSerializer和Jackson2JsonRedisSerializer的区别,前者会自动添加类型信息,而后者可能需要手动设置。引用3中提到的StringRedisTemplate是专门处理字符串的,可以简单说明。 另外,注意事项部分需要包括启用Redis仓库、类型安全、多个实例的区分(引用1和2的@Qualifier),以及序列化器选择的影响。比如,使用不同的序列化器可能导致存储格式不同,需要保持一致性。 最后,生成相关问题,覆盖用户可能进一步想了解的内容,比如多个RedisTemplate实例的配置序列化器区别、类型转换异常处理等,参考提供的引用内容中的知识点。 需要检查是否符合所有系统指令,特别是使用中文回答,正确格式的代码块,以及引用标识。确保每个引用在回答中正确标注,比如引用3和引用4的内容在适当的地方添加[^3]和[^4]。</think>### RedisTemplate序列化配置步骤说明 #### 一、基础配置原理 RedisTemplate默认使用$JdkSerializationRedisSerializer$,会产生二进制数据且可读性差。推荐采用JSON序列化方式,需配置以下核心组件: 1. 键序列化器:通常使用$StringRedisSerializer$ 2. 值序列化器:推荐$Jackson2JsonRedisSerializer$或$GenericJackson2JsonRedisSerializer$ 3. Hash结构序列化器:需单独配置 #### 二、完整配置示例(Spring Boot) ```java @Configuration public class RedisConfig { @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) { RedisTemplate<String, Object> template = new RedisTemplate<>(); template.setConnectionFactory(factory); // 配置序列化器 Jackson2JsonRedisSerializer<Object> serializer = new Jackson2JsonRedisSerializer<>(Object.class); ObjectMapper om = new ObjectMapper(); om.activateDefaultTyping(om.getPolymorphicTypeValidator(), ObjectMapper.DefaultTyping.NON_FINAL); serializer.setObjectMapper(om); // 设置序列化规则 template.setKeySerializer(new StringRedisSerializer()); template.setValueSerializer(serializer); template.setHashKeySerializer(new StringRedisSerializer()); template.setHashValueSerializer(serializer); template.afterPropertiesSet(); return template; } } ``` #### 三、关键配置说明 1. **类型安全配置** ```java om.activateDefaultTyping(...); // 添加类型元数据[^4] ``` 此配置会在JSON中添加@class字段,确保反序列化时能正确识别原始类型 2. **字符串专用模板** ```java @Autowired private StringRedisTemplate stringRedisTemplate; // 内置String序列化器 ``` 3. **多实例区分** ```java @Bean("customTemplate") public RedisTemplate<String, User> customTemplate() { // 创建特定类型的模板[^1][^2] } ``` #### 四、操作示例 ```java // 写入对象 User user = new User("Alice", 30); redisTemplate.opsForValue().set("user:1001", user); // 读取对象(需显式类型转换) User cachedUser = (User) redisTemplate.opsForValue().get("user:1001"); // [^4] ``` #### 五、注意事项 1. 需在启动类添加@EnableRedisRepositories 2. 序列化器类型必须与操作数据类型匹配 3. 使用@Qualifier区分多个RedisTemplate实例 4. GenericJackson2JsonRedisSerializer与Jackson2JsonRedisSerializer的主要区别在于是否自动处理类型信息
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值