Redis序列化设置以及jetcache连接Redis序列化的设置过程

2024-03-01 0 686
目录
  • 1、问题
  • 2、Redis序列化的设置
  • 3、jetcache序列化设置
  • 总结

1、问题

问题:

我在使用jetchche进行连接redis的时候,存入redis的value一直使用的是redis默认的序列化方式,是使用的jdk序列化。

当我使用jetcache向redis存入一个对象

Redis序列化设置以及jetcache连接Redis序列化的设置过程

存入redis的结果:

Redis序列化设置以及jetcache连接Redis序列化的设置过程

这是使用jdk序列化的结果。

但是我记得使用redis的时候可以更改序列化方式为json序列化,如果使用json序列化的结果就是这样的:

Redis序列化设置以及jetcache连接Redis序列化的设置过程

我想把jetcache的序列化方式也改成这种可读性好的。

2、Redis序列化的设置

当我们使用springDataRedis依赖直接连接redis的时候我们默认使用的也是jdk序列化,此时我们存入这个user对象的结果就和这个是一样的。

Redis序列化设置以及jetcache连接Redis序列化的设置过程

这种序列化的方式可读性比较差。

更改序列化的方式:

@Configuration
public class RedisConfig {

@Bean
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory connectionFactory){
// 创建RedisTemplate对象
RedisTemplate<String, Object> template = new RedisTemplate<>();
// 设置连接工厂
template.setConnectionFactory(connectionFactory);
// 创建JSON序列化工具
GenericJackson2JsonRedisSerializer jsonRedisSerializer =
new GenericJackson2JsonRedisSerializer();
// 设置Key的序列化
template.setKeySerializer(RedisSerializer.string());
template.setHashKeySerializer(RedisSerializer.string());
// 设置Value的序列化
template.setValueSerializer(jsonRedisSerializer);
template.setHashValueSerializer(jsonRedisSerializer);
// 返回
return template;
}
}

此时我们就可以进行接送序列化存入redis的就是这样的:

Redis序列化设置以及jetcache连接Redis序列化的设置过程

这样存入redis的时候因为前面会加上一串这个对象的信息,这样也额外占用了空间。

如果我们需要解决占用的这部分空间,我们可以手动进行JSON序列化,然后同一使用String序列化器。

@Autowired
private StringRedisTemplate stringRedisTemplate;
// JSON序列化工具
private static final ObjectMapper mapper = new ObjectMapper();

@Test
void testSaveUser() throws JsonProcessingException {
// 创建对象
User user = new User(\”虎哥\”, 21);
// 手动序列化
String json = mapper.writeValueAsString(user);
// 写入数据
stringRedisTemplate.opsForValue().set(\”user:200\”, json);

// 获取数据
String jsonUser = stringRedisTemplate.opsForValue().get(\”user:200\”);
// 手动反序列化
User user1 = mapper.readValue(jsonUser, User.class);
System.out.println(\”user1 = \” + user1);
}

此时,存入的json字符串就没有了前面类的信息。

3、jetcache序列化设置

我们使用jetcache使用redis作为远程缓存时,默认序列化工具也是使用的JDK序列化,jetcahce提供的配置文件中有这么一项:keyConvertor,这个配置可以指定为alibaba的fastjson的序列化工具,但是这个修改的时key的序列化,而不是value。

我们还是达不到提高可读性的效果。

这是官方提供的jetcache的配置:

jetcache:
statIntervalMinutes: 15
areaInCacheName: false
local:
default:
type: linkedhashmap #other choose:caffeine
keyConvertor: fastjson2 #other choose:fastjson/jackson
limit: 100
remote:
default:
type: redis
keyConvertor: fastjson2 #other choose:fastjson/jackson
broadcastChannel: projectA
valueEncoder: java #other choose:kryo/kryo5
valueDecoder: java #other choose:kryo/kryo5
poolConfig:
minIdle: 5
maxIdle: 20
maxTotal: 50
host: ${redis.host}
port: ${redis.port}

我们可以看到有个配置叫做valueEncoder和valueDecoder。这个配置才是真正的value的序列化工具。

这个配置jetcache给我们提供了三个选择,分别是:java(jdk序列化),kryo和kryo5。

并不能改成json序列化。

总结

单独使用redis的时候可以改序列化工具为json序列化,但是更推荐使用手动序列化然后直接存String,这样更省空间。

如果使用jetcache的时候只能改为jdk,kryo序列化工具,暂时不支持使用json序列化工具。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持悠久资源。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

悠久资源 Redis Redis序列化设置以及jetcache连接Redis序列化的设置过程 https://www.u-9.cn/database/redis/176898.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务