Redis序列化设置以及jetcache连接Redis序列化的设置过程
作者:东莞呵呵
1、问题
问题:
我在使用jetchche进行连接redis的时候,存入redis的value一直使用的是redis默认的序列化方式,是使用的jdk序列化。
当我使用jetcache向redis存入一个对象
存入redis的结果:
这是使用jdk序列化的结果。
但是我记得使用redis的时候可以更改序列化方式为json序列化,如果使用json序列化的结果就是这样的:
我想把jetcache的序列化方式也改成这种可读性好的。
2、Redis序列化的设置
当我们使用springDataRedis依赖直接连接redis的时候我们默认使用的也是jdk序列化,此时我们存入这个user对象的结果就和这个是一样的。
这种序列化的方式可读性比较差。
更改序列化的方式:
@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的时候因为前面会加上一串这个对象的信息,这样也额外占用了空间。
如果我们需要解决占用的这部分空间,我们可以手动进行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序列化工具。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。