本文主要是介绍微服务分布式缓存:无法反序列化 Cannot deserialize;,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
问题描述
在拆分SpringBoot项目搭建微服务的过程中,需要配置分布式缓存,对redis进行配置,配置完成后,在启动Knife4j文档界面时报错,发现是redis无法反序列化的问题,但是报错中所指出的类com.jhin.jhinoj.model.entity.User
已经实现了序列化接口
问题解决
我的微服务对应的redis数据库中本身存在数据,是我在原先的单体服务中进行登录操作所存下的,由于前后包路径不同,这个数据已经无法在新的微服务项目中反序列化成实例,所以每当服务模块连接redis数据库时就会产生无法反序列化的问题
我在指定redis数据库中清除了原先单体项目缓存的数据,至此,错误解除
什么是序列化与反序列化?
参考:什么是序列化-什么是反序列化
核心报错内容
org.springframework.data.redis.serializer.SerializationException: Cannot deserialize; nested exception is
org.springframework.core.serializer.support.SerializationFailedException: Failed to deserialize payload.
Is the byte array a result of corresponding serialization for DefaultDeserializer?;
nested exception is org.springframework.core.NestedIOException: Failed to deserialize object type;
nested exception is java.lang.ClassNotFoundException: com.jhin.jhinoj.model.entity.User
这篇关于微服务分布式缓存:无法反序列化 Cannot deserialize;的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!