【异常】com.alicp.jetcache.support.CacheEncodeException: Java Encode error.

简介: 【异常】com.alicp.jetcache.support.CacheEncodeException: Java Encode error.

Spring boot 项目集成 AlibabaJetCache 缓存开源框架。

Spring boot 集成 JetCache 框架之后,在需要添加缓存的方法上添加注解(@Cached)即可。已开启 本地缓存 + 远程缓存。示例代码如下:

上述方法中的返回值是 JavaBean 类型的,而我项目中的 JavaBean 代码如下:

注意:这个 JavaBean 没有实现序列化接口(这里是重点哦)。

在程序给这个方法远程缓存时,系统报错如下:

com.alicp.jetcache.support.CacheEncodeException: Java Encode error. msg=com.iot.back.message.process.dto.DeviceBasicInfoDTO
  at com.alicp.jetcache.support.JavaValueEncoder.apply(JavaValueEncoder.java:57)
  at com.alicp.jetcache.support.JavaValueEncoder.apply(JavaValueEncoder.java:13)
  at com.alicp.jetcache.redis.RedisCache.do_PUT(RedisCache.java:169)
  at com.alicp.jetcache.AbstractCache.PUT(AbstractCache.java:242)
  at com.alicp.jetcache.MultiLevelCache.PUT_caches(MultiLevelCache.java:193)
  at com.alicp.jetcache.MultiLevelCache.do_PUT(MultiLevelCache.java:164)
  at com.alicp.jetcache.AbstractCache.PUT(AbstractCache.java:242)
  at com.alicp.jetcache.MultiLevelCache.PUT(MultiLevelCache.java:66)
  at com.alicp.jetcache.Cache.put(Cache.java:74)
  at com.alicp.jetcache.SimpleProxyCache.put(SimpleProxyCache.java:43)
  at com.alicp.jetcache.AbstractCache.lambda$computeIfAbsentImpl$2(AbstractCache.java:153)
  at com.alicp.jetcache.AbstractCache.computeIfAbsentImpl(AbstractCache.java:163)
  at com.alicp.jetcache.RefreshCache.computeIfAbsent(RefreshCache.java:61)
  at com.alicp.jetcache.RefreshCache.computeIfAbsent(RefreshCache.java:56)
  at com.alicp.jetcache.anno.method.CacheHandler.invokeWithCached(CacheHandler.java:245)
  at com.alicp.jetcache.anno.method.CacheHandler.doInvoke(CacheHandler.java:92)
  at com.alicp.jetcache.anno.method.CacheHandler.invoke(CacheHandler.java:84)
  at com.alicp.jetcache.anno.aop.JetCacheInterceptor.invoke(JetCacheInterceptor.java:74)
  at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
  at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:688)
  at com.iot.back.message.process.rpc.DeviceBasicInfoRpc$$EnhancerBySpringCGLIB$$a4ce3e3e.getDeviceBasicInfo(<generated>)
  at com.iot.back.message.process.domain.service.impl.DeviceReportServiceImpl.report2AlarmMessageDTO(DeviceReportServiceImpl.java:118)
  at com.iot.back.message.process.domain.service.impl.DeviceReportServiceImpl.execute(DeviceReportServiceImpl.java:54)
  at com.iot.back.message.process.apps.impl.ReportRouteServiceImpl.route(ReportRouteServiceImpl.java:56)
  at com.iot.back.message.process.apps.impl.ReportMessageResolveImpl.report2log(ReportMessageResolveImpl.java:26)
  at com.iot.back.message.process.kafka.listener.ReportConsumerListener.lambda$kafkaConsumer$0(ReportConsumerListener.java:36)
  at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
  at java.util.concurrent.FutureTask.run(FutureTask.java:266)
  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
  at java.lang.Thread.run(Thread.java:748)
Caused by: java.io.NotSerializableException: com.iot.back.message.process.dto.DeviceBasicInfoDTO
  at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1184)
  at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1548)
  at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1509)
  at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1432)
  at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1178)
  at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:348)
  at com.alicp.jetcache.support.JavaValueEncoder.apply(JavaValueEncoder.java:48)
  ... 30 common frames omitted


相关文章
|
3天前
|
Java
Java异常捕捉处理和错误处理
Java异常捕捉处理和错误处理
8 1
|
5天前
|
Java 编译器 开发者
Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面
本文探讨了Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面,帮助开发者提高代码质量和程序的健壮性。
12 2
|
12天前
|
Java
如何在 Java 中处理“Broken Pipe”异常
在Java中处理“Broken Pipe”异常,通常发生在网络通信中,如Socket编程时。该异常表示写入操作的另一端已关闭连接。解决方法包括:检查网络连接、设置超时、使用try-catch捕获异常并进行重试或关闭资源。
|
14天前
|
存储 安全 Java
如何避免 Java 中的“ArrayStoreException”异常
在Java中,ArrayStoreException异常通常发生在尝试将不兼容的对象存储到泛型数组中时。为了避免这种异常,确保在操作数组时遵循以下几点:1. 使用泛型确保类型安全;2. 避免生类型(raw types)的使用;3. 在添加元素前进行类型检查。通过这些方法,可以有效防止 ArrayStoreException 的发生。
|
15天前
|
人工智能 Oracle Java
解决 Java 打印日志吞异常堆栈的问题
前几天有同学找我查一个空指针问题,Java 打印日志时,异常堆栈信息被吞了,导致定位不到出问题的地方。
29 2
|
19天前
|
Java 索引
如何避免在 Java 中引发`StringIndexOutOfBoundsException`异常
在Java中,处理字符串时若访问了不存在的索引,会抛出`StringIndexOutOfBoundsException`异常。为避免此异常,应确保索引值在有效范围内,例如使用`length()`方法检查字符串长度,并确保索引值不小于0且不大于字符串长度减1。
|
21天前
|
安全 Java 数据安全/隐私保护
如何配置 Java 安全管理器来避免访问控制异常
配置Java安全管理器以防止访问控制异常,需在启动JVM时通过 `-Djava.security.manager` 参数启用,并设置安全策略文件,定义权限规则,限制代码执行操作,确保应用安全。
|
27天前
|
Java
让星星⭐月亮告诉你,Java异常分类[Throwable(Error/Exception(RuntimeException/其他异常)) 检查时异常 非检查时异常]
本文深入解析了Java异常处理机制,重点介绍了`Throwable`类及其子类`Error`和`Exception`,并通过实例代码、流程图和表格详细解释了异常的分类、区别及处理方法,帮助读者掌握异常处理的关键技巧,提升程序的稳定性和健壮性。
45 1
|
1月前
|
Java 程序员
关于java异常
关于java异常
22 5
|
1月前
|
Java 程序员 编译器
Java中的异常类型
Java中的异常类型
22 3
下一篇
无影云桌面