上文:RabbitMQ工作模式
代码地址: https://gitee.com/never_enough/rabbitmqtest
参考RabbitMQ官网:RabbitMQ Tutorials
在使用RabbitMQ的时候,消息生产者发送消息不希望出现消息丢失或者投递失败的现象;
RabbitMQ在消息投递可靠性方面给我们提供了两种模式:
- confirm确认模式
- return 退回模式
rabbitmq-消息可靠性传递
1. confirm确认模式
消息确认,是指生产者消息投递后,如果Broker收到消息,则会给生产者一个应答,
生产者进行接收应答,用来确定这条消息是否正常的发送到Broker,这种方式也是消息的可靠性投递的核心保障
1.1 配置文件设置
1.2 实现RabbitTemplate.ConfirmCallback接口,实现confirm方法
/**
*
* @param correlationData 消息唯一标识, 存在的意义便是:如果消息发送失败,可以根据这个标识补发消息
* @param ack 交换机是否成功收到消息 true成功 false失败
* @param cause 失败原因
*/
@Override
public void confirm(CorrelationData correlationData, boolean ack, String cause) {
System.out.println("confirm方法被执行了..."+correlationData);
if(ack){
System.out.println("交换机 ,消息接收成功"+cause);
}else{
System.out.println("交换机 ,消息接收失败"+cause);
// 我们这里要做一些消息补发的措施
System.out.println("id="+correlationData.getId());
}
}
1.3 注入RabbitTemplate模版
@Autowired
private RabbitTemplate rabbitTemplate;
1.4 初始化设置
@PostConstruct
public void init(){
rabbitTemplate.setConfirmCallback(this);
// rabbitTemplate.setReturnCallback(this);
}
1.5 发送数据测试
/**
* String exchange 交换机名称
* String routingKey 路由Key
* Object object 具体发送的消息
* @param message
*/
@Override
public void sendMessage(String message) {
//发送的时候携带的数据,唯一标识
CorrelationData correlationData=new CorrelationData("3453");
//amqpTemplate.convertAndSend(RabbitMQConfig.DIRECT_EXCHANGE,RabbitMQConfig.DIRECT_ROUTINGKEY,message);
rabbitTemplate.convertAndSend(RabbitMQConfig.DIRECT_EXCHANGE,RabbitMQConfig.DIRECT_ROUTINGKEY,message, correlationData);
}
2. return 退回模式
Return Listener用于处理一些不可路由的消息
我们的消息生产者,通过制定一个Exchange和RoutingKey,把消息送达到某一个队列中去,然后我们消费者监听队列,进行消费处理。但是在某些情况下,如果我们在发送消息的时候,当前的exchange不存在或指定的路由key路由不到,这个时候我们需要监听这种不可达的消息,Return Listener
2.1 配置文件设置
2.2 实现RabbitTemplate.ReturnCallback接口,实现returnedMessage方法
/**
*
* @param message 消息主体
* @param replyCode 返回code
* @param replyText 返回信息
* @param exchange 交换机
* @param routingKey 路由key
*/
@Override
public void returnedMessage(Message message, int replyCode, String replyText, String exchange, String routingKey) {
System.out.println("return方法被执行...");
System.out.println("消息主体:"+new String(message.getBody()));
System.out.println("replyCode:"+replyCode);
System.out.println("replyText:"+replyText);
System.out.println("exchange:"+exchange);
System.out.println("routingKey:"+routingKey);
}
2.3 注入RabbitTemplate模版
@Autowired
private RabbitTemplate rabbitTemplate;
2.4 初始化模板
@PostConstruct
public void init(){
rabbitTemplate.setConfirmCallback(this);
rabbitTemplate.setReturnCallback(this);
}
2.5 发送数据测试
参考学习:RabbitMQ消息可靠性传递