前一篇文章,写了消息发送确认的一些内容.
就是消息发送成功或失败的时候,都会调用confirmListener 或者returnListener.
如果消息发送成功,就不考虑了.当消息发送失败时,怎么处理这个消息呢.
1.自动重发
2.系统预警人工处理等
以上操作,都需要知道是哪条消息,具体什么内容发送失败了,才能进行后续处理.
在returnListener中,参数是有消息内容,exchange,routingKey 这些内容的.
但是在confirmListener中,却是什么都没有,只有个correlationData,而我们打印出的correlationData都是null
看来问题的关键就在这个correlationData上了, CorrelationData类只有一个属性ID, 很明显,我们在发送消息时,将消息和correlationData的ID做一个绑定,就可以根据id拿到消息. 然后进行重发,报警等操作了.
本文讨论了RabbitMQ消息发送失败后的处理方法,包括自动重发和系统预警。通过利用CorrelationData的ID与消息绑定,实现消息确认和返回时的处理。文章提到了使用RabbitTemplate而非AmqpTemplate的重要性,并指出在确认或返回失败时的解决方案,以及如何处理超时未确认的消息。同时,强调了消费端在自动重发时需进行幂等性或重复消息处理。
最低0.47元/天 解锁文章
6368

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



