错误:RabbitMq
java.lang.IllegalArgumentException: SimpleMessageConverter only supports String, byte[] and Serializable payloads, received: com.yocoto.yocotoadmin.entity.Dto.MqDto。
场景描述:
之前使用一个Map来接受RabbitMq发送的数据。:
//声明监听的队列 (监听的是死信队列的备用队列)
@RabbitListener(queues = "REDIRECT_QUEUE")
@RabbitHandler
public void processDead(Map map) {
项目里都是禁止Map传、收参的,便于后期的阅读维护。
所以封装到一个Dto(Data Transport Object)来接受参数。
//声明监听的队列 (监听的是死信队列的备用队列)
@RabbitListener(queues = "REDIRECT_QUEUE")
@RabbitHandler
public void processDead(MqDto mqDto) {
错误解读:
很明显SimpleMessageConverter 简单模式消息发送者仅支持:String
、byte[]
,Serializable
[实现了序列化接口的对象]。
解决:
public class MqDto implements Serializable {
即可解决。
PS:我们的项目,使用RabbitMq的原因是本着它的死信队列去的。
其实就是实现了定时任务这样一个场景应用。
开启一个定时任务代表着出货逻辑,
定时60秒后去查询数据库订单pay的标识isPay的值,如果代表没有出货则退款。
如果需要此demo的话请联系 wx:pxl10251025