Spring Boot 集成 RabbitMQ 并实现消息确认机制

1. 引言

在 Spring Boot 项目中,RabbitMQ 是一种常见的消息中间件,用于实现异步通信。为了确保消息可靠传输,我们需要配置 RabbitTemplate,并实现 ConfirmCallbackReturnsCallback 两种回调机制。

本文将介绍如何在 Spring Boot 中

2. RabbitMQ 配置类

首先,我们创建 RabbitMqConfig 配置类:

集成 RabbitMQ,并详细讲解 RabbitTemplate 的使用。

java 复制代码
@EnableRabbit
@Configuration
public class RabbitMqConfig {

    private static Logger log = LoggerFactory.getLogger(RabbitMqConfig.class);

    @Bean
    RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory) {
        RabbitTemplate rabbitTemplate = new RabbitTemplate();
        rabbitTemplate.setConnectionFactory(connectionFactory);
        
        // 必须设置为 true,否则消息投递失败不会触发 ReturnCallback
        rabbitTemplate.setMandatory(true);

        // 消息发送确认回调
        rabbitTemplate.setConfirmCallback((correlationData, ack, cause) -> {
            String messageId = correlationData != null ? correlationData.getId() : "null";
            if (ack) {
                log.info("消息成功发送到交换机,消息ID:{}", messageId);
            } else {
                log.error("消息发送到交换机失败,消息ID:{},原因:{}", messageId, cause);
            }
        });

        // 消息路由失败回调
        rabbitTemplate.setReturnsCallback(returned -> {
            String correlationId = returned.getMessage().getMessageProperties()
                    .getHeader("spring_returned_message_correlation");
            log.error("消息发送失败,ID:{},应答码:{},原因:{},交换机:{},路由键:{}",
                    correlationId, returned.getReplyCode(), returned.getReplyText(),
                    returned.getExchange(), returned.getRoutingKey());
        });
        
        return rabbitTemplate;
    }
}

3. 消息投递的四种情况

在使用 RabbitMQ 时,消息投递可能遇到以下四种情况:

  1. 消息推送到 RabbitMQ 服务器,但找不到交换机

    • ConfirmCallback 被触发,ack = false
  2. 消息推送到服务器,找到交换机,但找不到队列

    • ConfirmCallback 被触发,ack = true

    • ReturnsCallback 也会被触发

  3. 消息推送到服务器,既找不到交换机,也找不到队列

    • ConfirmCallback 被触发,ack = false
  4. 消息推送成功

    • ConfirmCallback 被触发,ack = true

4. 发送消息示例

java 复制代码
@Autowired
private RabbitTemplate rabbitTemplate;

public void sendMessage(String exchange, String routingKey, String message) {
    CorrelationData correlationData = new CorrelationData(UUID.randomUUID().toString());
    rabbitTemplate.convertAndSend(exchange, routingKey, message, correlationData);
    log.info("发送消息:{},交换机:{},路由键:{},消息ID:{}", message, exchange, routingKey, correlationData.getId());
}

5. 总结

通过 RabbitTemplate 配置 ConfirmCallbackReturnsCallback,我们可以确保消息的可靠投递,并在失败时进行日志记录或重试处理。本文的示例适用于 Spring Boot 2.x 及以上版本,实际使用时可结合具体业务需求进行优化。

希望这篇文章能帮助你更好地理解 RabbitMQ 在 Spring Boot 中的使用!

相关推荐
goTsHgo1 小时前
Spring Boot 自动装配原理详解
java·spring boot
计算机毕设定制辅导-无忧学长2 小时前
RabbitMQ 核心概念与消息模型深度解析(一)
分布式·rabbitmq
秋野酱5 小时前
基于javaweb的SpringBoot爱游旅行平台设计和实现(源码+文档+部署讲解)
java·spring boot·后端
qq_12498707535 小时前
原生小程序+springboot+vue医院医患纠纷管理系统的设计与开发(程序+论文+讲解+安装+售后)
java·数据库·spring boot·后端·小程序·毕业设计
伊成6 小时前
一文详解Spring Boot如何配置日志
java·spring boot·单元测试
bing_1586 小时前
Spring Boot 的自动配置为 Spring MVC 做了哪些事情?
spring boot·spring·mvc
嘵奇9 小时前
Spring Boot中HTTP连接池的配置与优化实践
spring boot·后端·http
椰椰椰耶9 小时前
【RabbitMQ】工作队列和发布/订阅模式的具体实现
分布式·rabbitmq·ruby
Persistence___10 小时前
SpringBoot中的拦截器
java·spring boot·后端
嘵奇10 小时前
Spring Boot 跨域问题全解:原理、解决方案与最佳实践
java·spring boot·后端