自定义Redis序列化工具

SpringBoot的RedisAutoConfiguration默认使用JdkSerializationRedisSerializer,但其序列化后的数据不易阅读和反序列化。因此,需要自定义Redis配置类,如使用StringRedisSerializer和FastJsonRedisSerializer。本文探讨了不同序列化工具的优缺点,如Jackson2JsonRedisSerializer和GenericJackson2JsonRedisSerializer,并给出了自定义序列化类和配置示例。
摘要由CSDN通过智能技术生成

为什么用户需要自己创建一个redis配置类?

SpringBoot提供了对Redis的自动配置功能,在RedisAutoConfiguration类中默认为我们配置了客户端连接(Lettuce和Jedis),以及数据操作模板(StringRedisTemplate和RedisTemplate),下列代码有一个@ConditionalOnMissingBean和@Bean的注解,@ConditionalOnMissingBean注解判断是否执行初始化代码,即如果用户已经创建了bean,则相关的初始化代码不再执行。这导致了默认的是redisTemplate方法会被执行。
在这里插入图片描述
RedisTemplate是Spring提供用于操作redis数据库的一个类。将数据存放到Redis中,以及数据读取。这里必然涉及到数据的序列化和反序列化。RedisTemplate默认的系列化类是JdkSerializationRedisSerializer,用JdkSerializationRedisSerializer序列化的话,被序列化的对象必须实现Serializable接口。在存储内容时,除了属性的内容外还存了其它内容在里面,总长度长,且不容易阅读。所以才需要创建一个redis的配置类覆盖默认的序列化。我们要求是存储的数据可以方便查看,也方便反系列化,方便读取数据。
在这里插入图片描述
spring为我们提供了多种序列化方式,都在org.springframework.data.redis.serializer包下,常用的分别是:

  • JdkSerializationRedisSerializer
  • GenericJackson2JsonRedisSerializer
  • StringRedisSerializer
  • Jackson2JsonRedisSerializer

JacksonJsonRedisSerializer是spring提供的序列化工具,GenericJackson2JsonRedisSerializer是fastjson提供的json序列化工具,两者都能把字符串序列化成json,但是后者会在json中加入 @cla

RedisCacheManager是Spring提供的一个缓存管理器,用于将数据缓存在Redis中。如果需要自定义RedisCacheManager,可以继承它并重写相关方法。 首先,需要创建一个类,继承RedisCacheManager: ``` public class CustomRedisCacheManager extends RedisCacheManager { public CustomRedisCacheManager(RedisOperations redisOperations) { super(redisOperations); } @Override protected RedisCache createCache(String cacheName) { // 自定义缓存实现 return new CustomRedisCache(cacheName, (isUsePrefix() ? getCachePrefix().prefix(cacheName) : null), getRedisOperations(), getExpiration()); } } ``` 在这个类中,我们重写了createCache方法,用于创建自定义的缓存实现。我们可以创建一个CustomRedisCache类,继承RedisCache,然后在这个类中实现自己的缓存逻辑。 例如,下面是一个简单的CustomRedisCache实现: ``` public class CustomRedisCache extends RedisCache { public CustomRedisCache(String name, byte[] prefix, RedisOperations<? extends Object, ? extends Object> redisOperations, long expiration) { super(name, prefix, redisOperations, expiration); } @Override public ValueWrapper get(Object key) { // 自定义缓存逻辑 return super.get(key); } @Override public void put(Object key, Object value) { // 自定义缓存逻辑 super.put(key, value); } @Override public void evict(Object key) { // 自定义缓存逻辑 super.evict(key); } @Override public void clear() { // 自定义缓存逻辑 super.clear(); } } ``` 在这个CustomRedisCache类中,我们重写了RedisCache中的get、put、evict和clear方法,用于实现自己的缓存逻辑。 最后,在Spring配置文件中,使用自定义RedisCacheManager代替默认的RedisCacheManager。例如: ``` <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate"> <!-- Redis连接工厂 --> <property name="connectionFactory" ref="redisConnectionFactory"/> <!-- Redis序列化工具 --> <property name="valueSerializer" ref="jackson2JsonRedisSerializer"/> <property name="hashValueSerializer" ref="jackson2JsonRedisSerializer"/> </bean> <bean id="cacheManager" class="com.example.CustomRedisCacheManager"> <constructor-arg ref="redisTemplate"/> <property name="cacheNames"> <list> <value>cache1</value> <value>cache2</value> </list> </property> <property name="defaultExpiration" value="60"/> </bean> ``` 在这个配置中,我们创建了一个CustomRedisCacheManager,并设置了缓存名称和默认过期时间。注意,这里的redisTemplate需要自己定义,并设置好相关属性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值