RabbitMQ高级特性-消费端限流

本文介绍了RabbitMQ的消费端限流特性,强调了在消息积压或生产速度过快时,消费者应如何限制消息获取,避免服务崩溃。通过设置QoS(服务质量保证),特别是`prefetchCount`参数,可以确保消费者在确认前不会接收超过指定数量的消息。此外,还提到了`basicQos`方法的其他参数,并提供了代码示例来展示如何自定义消费者并关闭自动签收。
摘要由CSDN通过智能技术生成

消费端限流

  • 消息队列中囤积了大量的消息, 或者某些时刻生产的消息远远大于消费者处理能力的时候, 这个时候如果消费者一次取出大量的消息, 但是客户端又无法处理, 就会出现问题, 甚至可能导致服务崩溃, 所以需要对消费端进行限流

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

    • 自动签收要设置成false, 建议实际工作中也设置成false
    • void basicQos(int prefetchSize, int prefetchCount, boolean global) throws IOException;
    • prefetchSize : 消息大小限制, 一般设置为0, 消费端不做限制
    • prefetchCount : 会告诉RabbitMQ不要同时给一个消费者推送多于N个消息, 即一旦有N个消息还没有ack, 则该consumer将block(阻塞), 直到有消息ack
    • global : true/false 是否将上面设置应用于channel, 简单来说就是上面的限制是channel级别的还是consumer级别

    注意 :

    • prefetchSize和global这两项, RabbitMQ没有实现, 暂且不关注, prefetchCount在autoAck设置false的情况下生效, 即在自动确认的情况下这两个值是不生效的

代码演示

自定义消费者, 设置手动签收消息

package com.qiyexue.api.limit;

import com.rabbitmq.client.AMQP;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.DefaultConsumer;
import com.rabbitmq.client.Envelope;

import java.io.IOException;

/**
 * 自定义消费者
 * @author 七夜雪
 * @date 2018-12-16 8:20
 */
public class MyConsumer extends DefaultConsumer {
   

    private Channel channel;

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

    @Override
    public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
   
        System.out.println
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值