springboot整合rabbitMQ系列9 消费者Consumer限流

该博客介绍了如何在高并发场景下保护系统,防止因大量请求导致服务挂掉。通过配置RabbitMQ的`application.yml`文件启用手动ACK和设置消费限制,确保稳定处理每秒5000个请求。消费者代码展示了如何使用Jackson2JsonMessageConverter进行消息序列化,并定义了手动ACK的接收消息方法,通过延迟确认和批量处理来控制消费速度。
摘要由CSDN通过智能技术生成

场景:请求瞬间增多,每秒5000个请求,防止A系统挂掉

å¨è¿éæå¥å¾çæè¿°
注意:一定要开启手动ack确认

1 application.yml配置文件

server:
  port: 8021
spring:
  #给项目来个名字
  application:
    name: rabbitmq-test
  #配置rabbitMq 服务器
  rabbitmq:
    host: 127.0.0.1
    port: 5672
    username: need
    password: 123456
    #虚拟host 可以不设置,使用server默认host
    virtual-host: /testhost

    listener:
      simple:
        acknowledge-mode: manual #手动ACK
        max-concurrency: 10 #消费之最大数量
        concurrency: 1 #消费者最小数量
        prefetch: 2 #在单个请求中处理的消息个数,他应该大于等于事务数量(unack的最大数量)
      direct:
        acknowledge-mode: manual #手动ACK

2 消费者代码

        a:消息序列化转换

package org.example.service_b.config;

import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.amqp.support.converter.Jackson2JsonMessageConverter;
import org.springframework.amqp.support.converter.MessageConverter;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * 此代码添加 在消费者的项目中
 */
@Configuration
public class RabbitmqGlobalConfig {

    /**
     * 当发送的消息为pojo时,为报转换异常
     * 解决方法:添加这个类进行序列化解析
     * 会自动识别
     * @param objectMapper json序列化实现类
     * @return mq 消息序列化工具
     */
    @Bean
    public MessageConverter jsonMessageConverter(ObjectMapper objectMapper) {
        return new Jackson2JsonMessageConverter(objectMapper);
    }

}

        b:接收消息 

import com.rabbitmq.client.Channel;
import org.springframework.amqp.core.Message;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;
import java.io.IOException;

@Component
public class DirectReceiver_1 {

    @RabbitListener(queues = "TestDirectQueue")//监听的队列名称 TestDirectQueue
    /**
     * 注意:后4个参数,需要生产者发送消息时加上,否则为报错,注解里添加 required=false 或 删除参数
     */    
    public void process(Message message,
                        Channel channel,
                        @Header(AmqpHeaders.DELIVERY_TAG) long deliveryTag,
                        @Header(AmqpHeaders.MESSAGE_ID) String messageId,
                        @Header(AmqpHeaders.CONSUMER_TAG) String consumerTag,
                        CorrelationData correlationData) throws IOException, InterruptedException {

        //long deliveryTag = message.getMessageProperties().getDeliveryTag();
        //或 
        //@Header(AmqpHeaders.DELIVERY_TAG) long deliveryTag

        //设置3秒的睡眠好看变化情况
        Thread.sleep(1000);

        try {
            String msgbody = new String(message.getBody());
            //1.接收转换消息
            System.out.println("DirectReceiver消费者 1 收到消息  : " + msgbody + " 编号: " + deliveryTag);

            //3. 手动签收
            channel.basicAck(deliveryTag, true);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

演示效果,注意看Unacked,并且查看idea控制台,消息是慢慢的读的

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值