JDK、JSON、Hash三种序列化区别

对redis的value使用以下序列化方式进行序列化操作:

1:JdkSerializationRedisSerializer:

2:GenericJackson2JsonRedisSerializer

3:StringRedisSerializer

下面一个个简单介绍以下

1:JdkSerializationRedisSerializer:

序列化java对象碰到下面的报错:

DefaultSerializer requires a Serializable payload but received an object of type [com.everestfortune.cf.bean.CaseInfoBean]

原因:使用JdkSerializationRedisSerializer序列化的Bean必须实现Serializable接口



2:Jackson2JsonRedisSerializer

获取redis中的数据碰到下面的报错:

2019-04-26 11:26:41.510 ERROR 11656 --- [nio-9076-exec-7] c.e.cf.controller.ApplyController

: redis获取数据失败,mes=Could not read JSON: Cannot construct instance of `java.time.LocalDate`

(no Creators, like default construct, exist):

cannot deserialize from Object value (no delegate- or property-based Creator)

原因:LocalDate这是java8新增的类,GenericJackson2JsonRedisSerializer序列化方式无法识别


 3:StringRedisSerializer

不能序列化Bean,只能序列化字符串类型的数据

如果value都是字符串类型,可以用该方式序列化


在上述报告结果的记事本中,总结说明每种系列化方式的优劣,以及最终测试结论,即哪种性能最快通过测试的知上述的三种序列化方式由于数据量较大,保存数据的时间大致相同,性能上是Jackson2JsonRedisSerializer较好第一种: 在Spring容器中配置RedisTemplate。key系列化器StringRedisSerializer。value系列化器为JdkSerializationRedisSerializer

消耗了27485的时间



第、二种:在Spring容器中配置RedisTemplate。key系列化器StringRedisSerializer。value系列化器为      Jackson2JsonRedisSerializer

消耗了23161的时间

            第三种:  在Spring容器中配置RedisTemplate。key系列化器StringRedisSerializer。hashKey系列化器              StringRedisSerializer,hashValue系列化器StringRedisSerializer

消耗了23890的时间

如果第三种采用 hashValue系列化器Jackson2JsonRedisSerializer那么效率就会大大提高


配置

你可能感兴趣的:(JDK、JSON、Hash三种序列化区别)