掌控消息全链路(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 "发送成功";
        }
    }
相关推荐
Ting-yu3 小时前
SpringCloud快速入门(7)---- 数据隔离
spring boot·spring·spring cloud
无人不xiao6 小时前
springBoot 实现 接口进度条
java·spring boot·后端
smileNicky6 小时前
Docker 部署 SpringBoot 项目超详细教程
spring boot·docker·容器
HLAIA光子7 小时前
这些Spring Boot写法已经过时了!
spring boot·后端
i220818 Faiz Ul8 小时前
宠物猫之猫咖管理系统|基于java + vue宠物猫之猫咖管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·宠物猫之猫咖管理系统
i220818 Faiz Ul8 小时前
二手交易系统|基于springboot + vue二手交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·二手交易系统
逍遥德8 小时前
SpringBoot自带TaskScheduler 接口实现定时任务的动态增、删、启、停。
java·spring boot·后端·中间件
奋斗的小乌龟11 小时前
langchain4j笔记-08
java·spring boot·笔记
小英雄大肚腩丶11 小时前
RabbitMQ消息队列
java·数据结构·spring boot·分布式·rabbitmq·java-rabbitmq
一 乐13 小时前
学院教学工作量统计|基于java+ vue学院教学工作量统计管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·学院教学工作量统计系统