当前位置: 首页 > news >正文

RabbitMQ反序列化失败:Failed to convert message

🎈 1 参考文档

RabbitMQ消费消息坑:failed to convert serialized Message content | jiuchengi-cnblogs


🔍2 问题描述

org.springframework.amqp.rabbit.support.ListenerExecutionFailedException: Failed to convert messageat org.springframework.amqp.rabbit.listener.adapter.MessagingMessageListenerAdapter.onMessage(MessagingMessageListenerAdapter.java:156) ~[spring-rabbit-2.4.5.jar:2.4.5]...
Caused by: org.springframework.amqp.support.converter.MessageConversionException: failed to convert serialized Message contentat org.springframework.amqp.support.converter.SimpleMessageConverter.fromMessage(SimpleMessageConverter.java:117) ~[spring-amqp-2.4.5.jar:2.4.5]at ...
Caused by: java.lang.IllegalStateException: Could not deserialize object typeat org.springframework.amqp.utils.SerializationUtils.deserialize(SerializationUtils.java:97) ~[spring-amqp-2.4.5.jar:2.4.5]at org.springframework.amqp.support.converter.SimpleMessageConverter.fromMessage(SimpleMessageConverter.java:113) ~[spring-amqp-2.4.5.jar:2.4.5]... 16 common frames omitted
Caused by: java.lang.ClassNotFoundException: com.cauli.file.model.dto.file.FileSearchDTOat java.net.URLClassLoader.findClass(URLClassLoader.java:382) ~[na:1.8.0_221]at java.lang.ClassLoader.loadClass(ClassLoader.java:424) ~[na:1.8.0_221]at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:349) ~[na:1.8.0_221]...

💡3 原因分析

这个异常信息表明在处理消息时出现了问题,具体地说,它是由于消息内容的反序列化失败引起的。以下为关键信息:

org.springframework.amqp.rabbit.support.ListenerExecutionFailedException: Failed to convert messageCaused by: org.springframework.amqp.support.converter.MessageConversionException: failed to convert serialized Message contentCaused by: java.lang.IllegalStateException: Could not deserialize object typeCaused by: java.lang.ClassNotFoundException: com.cauli.file.model.dto.file.FileSearchDTO

根据异常信息的内容,问题似乎是由于反序列化消息内容时找不到类 com.cauli.file.model.dto.file.FileSearchDTO 导致的。

我目前生产者和消费者都有一个FileSearchDTO对象,内容是一模一样的包括序列化,可就是消费者接收时报序列化错误。


🚀4 解决方案

4.1 共同使用一个对象

把这个对象放到公共模块,然后生产者和消费者服务引入这个公共模块,生产者和消费者发送和消费时共用一个对象。这样完全保证了两个项目中JavaBean是一致的,所以能解决反序列失败的问题。

缺点:局限性太小,这种模式生产者和消费者只能在同一个微服务下才能使用

4.2 消息JSON序列化

4.2.1 生产者发送消息JSON序列化

生产者添加配置:

/*** RabbitMQ配置** @author Tang* @version 1.0* @date 2022/05/02 23:23:27*/
@Configuration
public class RabbitMQConfig implements InitializingBean {/*** 自动注入RabbitTemplate模板*/@Resourceprivate RabbitTemplate rabbitTemplate;/*** 发送消息JSON序列化*/@Overridepublic void afterPropertiesSet() {//使用JSON序列化rabbitTemplate.setMessageConverter(new Jackson2JsonMessageConverter());}
}

4.2.2 消费者接收消息JSON反序列化

消费者添加配置:

/*** RabbitMQ配置** @author Tang* @version 1.0* @date 2022/05/02 23:23:27*/
@Configuration
public class RabbitMQConfig {@Beanpublic MessageConverter jsonMessageConverter(ObjectMapper objectMapper) {return new Jackson2JsonMessageConverter(objectMapper);}
}
http://www.lryc.cn/news/162375.html

相关文章:

  • CTFSHOW 年CTF
  • 肖sir__设计测试用例方法之状态迁移法05_(黑盒测试)
  • 无涯教程-JavaScript - IMPRODUCT函数
  • yapi以及gitlab的容器化部署
  • TCP、UDP 协议的区别,各自的应用场景
  • C高级 DAY3
  • Linux CentOS7命令及命令行
  • 【C++入门到精通】C++入门 ——搜索二叉树(二叉树进阶)
  • 学成在线-网站搭建
  • stm32同芯片但不同flash工程更换Device出现报错
  • Element UI实现每次只弹出一个Message消息提示
  • 「网页开发|前端开发|Vue」04 快速掌握开发网站需要的Vue基础知识
  • 解决Redis分布式锁主从架构锁失效问题的终极方案 含面试题
  • 建站系列(三)--- 网络协议
  • jetson orin nx无显示器启动
  • 【APUE】标准I/O库
  • es6---模块化
  • 【项目 计网12】4.32UDP通信实现 4.33广播 4.34组播 4.35本地套接字通信
  • 创建简单的 Docker 数据科学映像
  • angualr:CSS一个div内两个子元素的高度自适应
  • Java基础之static关键字
  • iPhone 15 Pro有5项重大设计升级,让iPhone 15看起来很无聊
  • xCode14.3.1运行MonkeyDev出现“Executable Not Found“的解决办法
  • C# Emgu.CV+Tesseract实现识别图像验证码
  • ORACLE 11.2.0.4 RAC Cluster not starting cssd with Cannot get GPnP profile
  • Converting Phase Noise to Random Jitter(Cycle-to-Cycle)
  • HashMap知识总结
  • PLC编码器测速(限幅滤波+中心差分法求导SCL源代码)
  • SW的stp文件转成CAD格式文件学习笔记
  • 【数据结构】栈---C语言版(详解!!!)