掌控消息全链路(4)——RabbitMQ/Spring-AMQP高级特性详解之事务与消息分发


🔥我的主页: 九转苍翎
⭐️个人专栏: 《Java SE》 《Java集合框架系统精讲》 《MySQL高手之路:从基础到高阶》 《计算机网络》 《Java工程师核心能力体系构建》 《RabbitMQ理论与实践》
天行健,君子以自强不息。


1.事务

AMQP(高级消息队列协议)实现了事务机制,主要用于确保消息的原子性发布和确认。换言之,它允许你将多个操作(如发送消息、确认消息)绑定在一起,要么全部成功,要么全部失败

  • 配置队列

    java 复制代码
    @Configuration
    public class RabbitMQConfig {
        @Bean("transQueue")
        public Queue transQueue(){
            return QueueBuilder.durable(Constants.TRANS_QUEUE).build();
        }
    }
  • 配置RabbitTemplate和事务管理器

    java 复制代码
    @Configuration
    public class RabbitTemplateConfig {
        @Bean("transRabbitTemplate")
        public RabbitTemplate transRabbitTemplate(ConnectionFactory connectionFactory) {
            RabbitTemplate rabbitTemplate = new RabbitTemplate(connectionFactory);
            rabbitTemplate.setChannelTransacted(true);
            return rabbitTemplate;
        }
    
        @Bean
        public RabbitTransactionManager rabbitTransactionManager(ConnectionFactory connectionFactory){
            return new RabbitTransactionManager(connectionFactory);
        }
    }
  • 发送消息

    java 复制代码
    @RestController
    @RequestMapping("/producer")
    public class ProducerController {
        @Resource(name = "transRabbitTemplate")
        private RabbitTemplate transRabbitTemplate;
        
        @Transactional
        @RequestMapping("/trans")
        public String trans(){
            transRabbitTemplate.convertAndSend("",Constants.TRANS_QUEUE, "trans test ---> 1");
            int num = 5 / 0;
            transRabbitTemplate.convertAndSend("",Constants.TRANS_QUEUE, "trans test ---> 2");
            return "发送成功";
        }
    }


    Spring Boot的RabbitMQ自动配置默认会确认模式,但RabbitMQ不允许同一个通道同时使用事务模式和确认模式,所以需要确保publisher confirms被禁用

    yaml 复制代码
    spring:
      rabbitmq:
        publisher-confirm-type: none
        publisher-returns: false

2.消息限流

消息限流(Flow Control) 是RabbitMQ防止生产者发送消息速度超过消费者处理能力,导致消息积压和系统崩溃的保护机制

  • 声明和配置交换器、队列和绑定关系

    java 复制代码
    @Configuration
    public class RabbitMQConfig {
        @Bean("qosQueue")
        public Queue qosQueue(){
            return QueueBuilder.durable(Constants.QOS_QUEUE).build();
        }
        @Bean("qosExchange")
        public DirectExchange qosExchange(){
            return ExchangeBuilder.directExchange(Constants.QOS_EXCHANGE).build();
        }
        @Bean("qosBinding")
        public Binding qosBinding(@Qualifier("qosExchange") DirectExchange directExchange,@Qualifier("qosQueue") Queue queue){
            return  BindingBuilder.bind(queue).to(directExchange).with("qos");
        }
    }
  • 限制每个消费者未确认的最大消息数

    yaml 复制代码
    spring:
      rabbitmq:
        listener:
          simple:
            acknowledge-mode: manual # 消费者确认机制
            prefetch: 5
  • 配置消费者

    java 复制代码
    @Component
    @Slf4j
    public class QosListener {
        @RabbitListener(queues = Constants.QOS_QUEUE)
        public void handMessage(Message message, Channel channel) throws IOException {
            long deliveryTag = message.getMessageProperties().getDeliveryTag();
            try{
                log.info("接收到消息:{},deliveryTag:{}",
                        new String(message.getBody(), StandardCharsets.UTF_8),
                        deliveryTag);
                log.info("处理成功");
                // channel.basicAck(deliveryTag, true); // 消费者不确认消息
            }catch(Exception e){
                channel.basicNack(deliveryTag,true,true);
            }
        }
    }
  • 发送消息

    java 复制代码
    @RestController
    @RequestMapping("/producer")
    public class ProducerController {
        @Resource(name = "rabbitTemplate")
        private RabbitTemplate rabbitTemplate;
        
        @RequestMapping("/qos")
        public String qos(){
            for (int i = 0; i < 20; i++) {
                rabbitTemplate.convertAndSend(Constants.QOS_EXCHANGE, "qos", "qos test:" + i);
            }
            return "发送成功";
        }
    }
相关推荐
计算机学姐14 小时前
基于SpringBoot的咖啡店管理系统【个性化推荐+数据可视化统计+配送信息】
java·vue.js·spring boot·后端·mysql·信息可视化·tomcat
My的梦想已实现14 小时前
关于JAVA Springboot集成支付后打包JAR之后报安全错误的处理
java·spring boot·jar
小江的记录本14 小时前
【注解】常见 Java 注解系统性知识体系总结(附《全方位对比表》+ 思维导图)
java·前端·spring boot·后端·spring·mybatis·web
Mr.456715 小时前
Spring Boot 集成 PostgreSQL 表级备份与恢复实战
java·spring boot·后端·postgresql
白露与泡影15 小时前
探索springboot程序打包docker的最佳方式
spring boot·后端·docker
sthnyph16 小时前
SpringBoot Test详解
spring boot·后端·log4j
brucelee18616 小时前
Spring Boot 测试最佳实践
spring boot·后端·log4j
DROm RAPS17 小时前
十七:Spring Boot依赖 (2)-- spring-boot-starter-web 依赖详解
前端·spring boot·后端
TlYf NTLE18 小时前
Spring Boot spring-boot-maven-plugin 参数配置详解
spring boot·后端·maven
花千树-01018 小时前
5分钟用 Java 构建你的第一个 AI 应用
java·人工智能·spring boot·langchain·aigc·ai编程