springboot--RabbitMQ中的消息确认

RabbitMQ的两种消息确认,publisherConfirms 和 publisherReturns。
  • publisherConfirms:消息发送到exchange,返回成功或者失败。
  • publishReturns:消息从exchange到queue,发送成功或者失败。
    具体操作看下方代码
  1. 消费者与生产者两方都要配置CachingConnectionFactory,其中将publisherConfirms,publishReturns开启,默认都是false
	@Bean
    @ConditionalOnClass
    public CachingConnectionFactory connectionFactory() {
        CachingConnectionFactory factory = new CachingConnectionFactory();
        factory.setHost("127.0.0.1");
        factory.setUsername("guest");
        factory.setPassword("guest");
        factory.setVirtualHost("/");
        factory.setPublisherConfirms(true);
        factory.setPublisherReturns(true);
        return factory;
    }
  1. 消息Procuder端:设置RabbitTemplate相关属性
	@Bean
    @ConditionalOnClass
    public RabbitTemplate template(CachingConnectionFactory connectionFactory) {
        RabbitTemplate template = new RabbitTemplate(connectionFactory);
        template.setConfirmCallback((correlationData, ack, cause) -> {
            LOGGER.info("confirm callback publish --> status of publihs message: {}", ack);
            LOGGER.info("confirm callback publish --> correlationData: {}", correlationData);
            LOGGER.info("confirm callback publish --> cause: {}", cause);
        });
        // 如果设置ReturnCallback,必须将Mandatory设置为true
        template.setMandatory(true);
        template.setReturnCallback((message, replyCode, replyText,
                                    exchange, routingKey) -> {
            LOGGER.info("return callbak exchange: {}, routingKey: {}, message:{}", exchange, routingKey, new String(message.getBody(), StandardCharsets.UTF_8));
        });
        return template;
    }

相关代码就是如此简单,验证时可以干掉exchange,这样就可以验证confirm。将queue与exchange解绑,可以验证returnCallback

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot 是一个方便快捷的轻量级框架,提供了许多便利的功能和特性,其就包括了 RabbitMQ 的整合功能。 RabbitMQ 是一个广泛使用的消息队列系统,具有高可靠性和可扩展性,能够在分布式系统实现异步通信、解耦和任务调度等功能,因此对于分布式系统而言具备非常重要的价值。 在Spring Boot,整合RabbitMQ 可以通过以下步骤完成: 1. 添加 RabbitMQ 的相关依赖:在 pom.xml 文件添加 spring-boot-starter-amqp 依赖。 2. 配置 RabbitMQ 相关信息:通过 application.yml 或 application.properties 配置文件配置RabbitMQ 的基本信息,例如:连接地址、用户名、密码等。 3. 创建 RabbitMQ 模板:通过 RabbitTemplate 类提供的方法向 RabbitMQ 发送消息并接收响应信息。 4. 创建 Exchange 和 Queue:在 RabbitMQ 创建 Exchange 和 Queue,Exchange 用于将消息路由到指定的 Queue 。 5. 编写发送消息的代码:通过 RabbitTemplate 提供的方法send()发送消息,可以是简单字符串/对象/json等。 至此,我们已经实现了一个简单的 RabbitMQ 消息发送程序。但是在实际应用场景,还需要具备更进一步完善的功能,例如:消息确认消息持久化、消费者监听等功能,这些可以通过配置listener容器、消息确认机制以及使用DurableQueue,DurableExchange等参数来实现。 总之,RabbitMQ’s and Spring Boot的集成非常方便和快捷。通过简单的配置和实现,我们就可以使用 RabbitMQ 在分布式系统实现异步通信、解决问题、任务调度等功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值