问题描述
在拆分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


在拆分SpringBoot项目为微服务时遇到Redis反序列化错误,原因是原有单体服务的缓存数据与新服务的包路径不匹配。解决办法是清除Redis中的旧数据并确保对象实现了序列化接口。序列化与反序列化是将数据转换为可存储或传输形式的过程。
6万+

被折叠的 条评论
为什么被折叠?



