美文网首页
RabbitMQ 消费端限流

RabbitMQ 消费端限流

作者: qyfl | 来源:发表于2019-09-26 22:25 被阅读0次

RabbitMQ 提供了一种 qos(服务质量保证)功能,即在非自动确认消息的前提下,如果一定数据的消息(通过基于 comsume 或者 channel 设置 qos 的值)未被确认前,不消费新的消息。

注意事项:

  • 消费者的 autoAck 要设置为 false。
  • 消费者要写确认消息的代码。

消费者代码:

import com.rabbitmq.client.*;

import java.io.IOException;
import java.util.concurrent.TimeoutException;

public class Consumer {
    public static void main(String[] args) throws IOException, TimeoutException {
        // 1. 创建一个 ConnectionFactory,并配置
        ConnectionFactory connectionFactory = new ConnectionFactory();
        connectionFactory.setHost("127.0.0.1");
        connectionFactory.setPort(5672);
        connectionFactory.setVirtualHost("/");

        // 2. 通过连接工厂创建连接
        Connection connection = connectionFactory.newConnection();

        // 3. 通过 connection 创建 Channel
        Channel channel = connection.createChannel();

        // 4. 声明一个队列
        String queueName = "test001";
        String exchangeName = "test_qos_exchange";
        String routingKey = "qos.#";
        channel.queueDeclare(queueName, true, false, false, null);
        channel.exchangeDeclare(exchangeName, "topic", true, true, null);
        channel.queueBind(queueName, exchangeName, routingKey);

        // 5. 创建消费者
        QueueingConsumer queueingConsumer = new QueueingConsumer(channel);

        // 6. 设置 Channel
        channel.basicQos(0,1,false);
        channel.basicConsume(queueName, false, new myComsumer(channel));
    }
}

自定义消费者:

import com.rabbitmq.client.*;

import java.io.IOException;

public class myComsumer extends DefaultConsumer {

    private Channel channel;

    public myComsumer(Channel channel) {
        super(channel);
        this.channel = channel;
    }

    @Override
    public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
        super.handleDelivery(consumerTag, envelope, properties, body);
        System.out.println("消费端:" + new String(body));

        channel.basicAck(envelope.getDeliveryTag(), false);
    }
}

相关文章

  • RabbitMQ 消费端限流

    RabbitMQ 提供了一种 qos(服务质量保证)功能,即在非自动确认消息的前提下,如果一定数据的消息(通过基于...

  • RabbitMQ高级特性(2)

    一、消费端限流 1.什么是消费端的限流 假设一个场景,首先,Rabbitmq服务器有上万条未处理的消息,我们随便打...

  • RabbitMQ消费端的限流策略

    假设一个场景,由于我们的消费端突然全部不可用了,导致rabbitMQ服务器上有上万条未处理的消息,这时候如果没做任...

  • RabbitMQ消费端的限流策略

    为什么需要消费端的限流? 假设一个场景,我们Rabbitmq服务器有上万条未处理的消息,我们随便打开一个消费者客户...

  • RabbitMQ消费端的限流策略

    为什么需要消费端的限流? 假设一个场景,我们Rabbitmq服务器有上万条未处理的消息,我们随便打开一个消费者客户...

  • RabbitMQ 消费端的限流策略

    假设一个场景,由于我们的消费端突然全部不可用了,导致 rabbitMQ 服务器上有上万条未处理的消息,这时候如果没...

  • RabbitMQ高级特性

    0. 前言 本文内容分为如下三部分RabbitMQ高级特性 消息可靠性投递Consumer ACK消费端限流TTL...

  • 消费端限流

    Producer Consumer 自定消息接收

  • 消息队列之RabbitMQ-高级应用

    1、消费限流 假设一个场景:Rabbitmq 服务器积压了有上万条未处理的消息,我们随便打开一个消费者客户端,会出...

  • RabbitMQ学习(五)消费端削峰限流

    1.MQ的作用 1)解耦:在项目启动之初是很难预测未来会遇到什么困难的,消息中间件在处理过程中插入了一个隐含的,基...

网友评论

      本文标题:RabbitMQ 消费端限流

      本文链接:https://www.haomeiwen.com/subject/mivquctx.html