springboot实现redis序列化和反序列化

序列化和反序列化

序列化是指将对象转换为字节序列的过程,以便于存储或传输。在序列化过程中,对象的状态信息将被转换为字节流,可以保存到文件中或通过网络传输给其他计算机。反序列化则是将字节序列恢复为对象的过程。
反序列化是指将字节序列恢复为对象的过程。在序列化中,对象的状态信息被转换为字节流以便于存储或传输,而在反序列化中,这些字节流将被重新转换为原始对象的状态。(PS:作者很久之前被问到当时脑子断片了没答出来哈哈~~)

说人话:就是对象和字节码互转

SpringBoot集成Redis有多种序列化和反序列化的方式(这里只举例常用的几种)

package com.excesys.config;

import com.alibaba.fastjson.support.spring.GenericFastJsonRedisSerializer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.RedisSerializer;

@Configuration
public class RedisConfig {

    @Bean
    public RedisTemplate redisTemplate(RedisConnectionFactory factory) {
        RedisTemplate template = new RedisTemplate();
        template.setConnectionFactory(factory);
        //redis序列化--key采用String的序列化方式,value采用json的序列化方式
//        template.setKeySerializer(RedisSerializer.string());
//        template.setHashKeySerializer(RedisSerializer.string());
//        template.setValueSerializer(RedisSerializer.json());
//        template.setHashValueSerializer(RedisSerializer.json());
        //Jackson序列化--key采用String的序列化方式,value采用Jackson的序列化方式
//        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
//        //序列化包括类型描述 否则反向序列化实体会报错,一律都为JsonObject
//        ObjectMapper mapper = new ObjectMapper();
//        mapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
//        mapper.activateDefaultTyping(mapper.getPolymorphicTypeValidator(), ObjectMapper.DefaultTyping.NON_FINAL);
//        jackson2JsonRedisSerializer.setObjectMapper(mapper);
//        template.setKeySerializer(RedisSerializer.string());
//        template.setHashKeySerializer(RedisSerializer.string());
//        template.setValueSerializer(jackson2JsonRedisSerializer);
//        template.setHashValueSerializer(jackson2JsonRedisSerializer);
        //FastJson序列化--key采用String的序列化方式,value采用FastJson的序列化方式
        GenericFastJsonRedisSerializer fastJsonRedisSerializer = new GenericFastJsonRedisSerializer();
        template.setKeySerializer(RedisSerializer.string());
        template.setHashKeySerializer(RedisSerializer.string());
        template.setValueSerializer(fastJsonRedisSerializer);
        template.setHashValueSerializer(fastJsonRedisSerializer);
        template.afterPropertiesSet();
        return template;
    }

}

几种方式的序列化和反序列化的取值耗时


    @Resource
    private RedisTemplate<String, Object> redisTemplate;

    @Test
    void contextLoads() {
        ProductOrder po = new ProductOrder(1l, "1752579478791368704", "Python书籍", 521.98, 3, "12345678901234567890");
        long st = System.currentTimeMillis();
        redisTemplate.opsForValue().set("test", po);
        ProductOrder test = (ProductOrder) redisTemplate.opsForValue().get("test");
        long et = System.currentTimeMillis();
        System.out.println("Reids序列化和反序列化:" + test + "耗时:" + (et - st));
    }

默认:

在这里插入图片描述
默认:ProductOrder(id=1, out_trade_no=1752579478791368704, subject=Python书籍, 、total_amount=521.98, order_status=3, product_code=12345678901234567890)耗时:1184
默认:ProductOrder(id=1, out_trade_no=1752579478791368704, subject=Python书籍, total_amount=521.98, order_status=3, product_code=12345678901234567890)耗时:1016
默认:ProductOrder(id=1, out_trade_no=1752579478791368704, subject=Python书籍, total_amount=521.98, order_status=3, product_code=12345678901234567890)耗时:1037

Jackson

在这里插入图片描述
jackson:ProductOrder(id=1, out_trade_no=1752579478791368704, subject=Python书籍, total_amount=521.98, order_status=3, product_code=12345678901234567890)耗时:1192
jackson:ProductOrder(id=1, out_trade_no=1752579478791368704, subject=Python书籍, total_amount=521.98, order_status=3, product_code=12345678901234567890)耗时:1042
jackson:ProductOrder(id=1, out_trade_no=1752579478791368704, subject=Python书籍, total_amount=521.98, order_status=3, product_code=12345678901234567890)耗时:1016

FastJson
在这里插入图片描述
fastjson:ProductOrder(id=1, out_trade_no=1752579478791368704, subject=Python书籍, total_amount=521.98, order_status=3, product_code=12345678901234567890)耗时:962
fastjson:ProductOrder(id=1, out_trade_no=1752579478791368704, subject=Python书籍, total_amount=521.98, order_status=3, product_code=12345678901234567890)耗时:1232
fastjson:ProductOrder(id=1, out_trade_no=1752579478791368704, subject=Python书籍, total_amount=521.98, order_status=3, product_code=12345678901234567890)耗时:1000

结论:fastjson>默认>=jackson

  • 20
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot项目中配置Redis序列化,可以通过修改配置文件来实现。首先,需要在项目的pom.xml文件中引入Redis的相关依赖,如引用所示。然后,在application.properties或application.yml文件中添加Redis的连接配置,如引用所示。其中,spring.redis.database表示选择的数据库编号,spring.redis.host表示Redis的主机名,spring.redis.port表示Redis的端口号,spring.redis.password表示Redis的密码(如果有密码的话)。 在配置Redis序列化方式时,可以使用Spring Boot提供的默认序列化方式,也可以自定义序列化方式。如果使用默认的序列化方式,Spring Boot会将对象序列化成字节数组存储在Redis中。如果需要自定义序列化方式,可以实现RedisSerializer接口,并在配置文件中指定使用自定义的序列化方式。 要使用Spring Boot提供的默认序列化方式,只需要在配置文件中添加如下配置即可: spring.redis.serializer=org.springframework.data.redis.serializer.JdkSerializationRedisSerializer 如果想要自定义序列化方式,可以先创建一个实现RedisSerializer接口的类,然后在配置文件中指定使用自定义的序列化方式,例如: spring.redis.serializer=com.example.MyRedisSerializer 请根据实际需求选择合适的序列化方式,并按照以上方式进行配置。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [SpringBoot中配置redis序列化方式实战](https://blog.csdn.net/nandao158/article/details/121939312)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [Spring boot 整合 Redis序列化配置](https://blog.csdn.net/weixin_43769525/article/details/109569084)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值