Spring Boot Redis 序列化方案的选择!

本文探讨了Spring Boot Redis的默认序列化方案及其性能瓶颈,提出使用FastJsonRedisSerializer和Kryo作为替代方案。FastJsonRedisSerializer提供更小的体积和更快的速度,但需手动配置。Kryo则在性能上有优势,但线程不安全,需通过池化处理。性能测试结果显示,选择合适的序列化方案能有效提升Redis的性能。
摘要由CSDN通过智能技术生成

Redis的使用越来越广泛,当遇见性能瓶颈时,我们应该如何去解决呢?

01 Spring Boot Redis

Spring Boot Data Redis给我们提供了即插即用的体验,大部分默认配置已经满足了我们的需求,而其中序列化方案选择的是原生的JdkSerializationRedisSerializer

1.1 RedisTemplate.java

if (defaultSerializer == null) {

    defaultSerializer = new JdkSerializationRedisSerializer(
            classLoader != null ? classLoader : this.getClass().getClassLoader());
}

当然,我们也可以选择Spring Boot Data Redis的其他序列化方案进行配置。

1.2 RedisSerializer的实现

 

在此基础上,我们可以自定义我们自己的序列化方案。

02 自定义JSON序列化方案

2.1 FastJsonRedisSerializer.java

public class FastJsonRedisSerializer<T> implements RedisSerializer<T> {
    private FastJsonConfig fastJsonConfig = new FastJsonConfig();
    private Class<T> type;

    public FastJsonRedisSerializer(Class<T> type) {
        this.type = type;
    }

    public FastJsonConfig getFastJsonConfig() {
        return fastJsonConfig;
    }

    public void setFastJsonConfig(FastJsonConfig fastJsonConfig) {
        this.fastJsonConfig = fastJsonConfig;
    }

    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值