RabbitMQ消息可靠性传递-confirm确认模式,return 退回模式

上文:RabbitMQ工作模式

代码地址: https://gitee.com/never_enough/rabbitmqtest

参考RabbitMQ官网:RabbitMQ Tutorials

在使用RabbitMQ的时候,消息生产者发送消息不希望出现消息丢失或者投递失败的现象;

RabbitMQ在消息投递可靠性方面给我们提供了两种模式:

  • confirm确认模式
  • return 退回模式

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消息可靠性传递

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值