RabbitMQ消息的可靠投递性
概念:使用RabbitMQ的时候,作为消息发送方(生产方)希望杜绝任何消息丢失或者投递失败场景,RabbitMQ为我们提供了两种方式用来控制消息的投递可靠性模式。
确认模式
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZQSTgkT8-1599276790210)(C:\Users\gwx\AppData\Roaming\Typora\typora-user-images\image-20200904181100860.png)]
确认模式就是消息从producer到exchange会返回一个confirmCallback的回调函数
1.在spring整合rabbitmq的配置文件中开启confirm模式
publisher-confirms="true"
2.在发送消息时用rabbitmq模板对象设置一回调函数,生产者将消息发送给交换机无论失败与否都会调用这个回调。
rabbitTemplate.setConfirmCallback(new RabbitTemplate.ConfirmCallback() {
@Override
// 配置信息, 是否成功发送消息, 错误信息
public void confirm(CorrelationData correlationData, boolean b, String s) {
System.out.println("confirm执行了");
if (b){
System.out.println("成功将消息发送给交换机");
}else {
System.out.println("发送消息失败,"+s);
}
}
});
退回模式
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9kfER1D1-1599276790213)(C:\Users\gwx\AppData\Roaming\Typora\typora-user-images\image-20200904181100860.png)]
退回模式就是交换机在通过路由key路由给队列时的回调函数
1.在配置文件中开启retrun模式
publisher-returns="true"
2.因为retrun这个模式如果交换机没有正常的把消息路由到指定的队列,这个消息会自动被丢弃,在代码中设置不自动丢弃,返回给生产者
// 设置如果队列没有拿到消息,会将消息返回给生产者,不会自动丢弃这条消息
rabbitTemplate.setMandatory(true);
rabbitTemplate.setReturnCallback(new RabbitTemplate.ReturnCallback() {
@Override // 发送消息对象 状态码 错误信息 交换机 ,路由键
public void returnedMessage(Message message, int i, String s, String s1, String s2) {