rabbitmq中的流量控制

35 篇文章 1 订阅
15 篇文章 1 订阅

1.流量控制的说明:开启客户端最大的未处理消息队列大小
2. 在python中的应用:channel.basic_qos(prefetch_count=1)

import pika


credentials = pika.PlainCredentials('baibing', '123456')
connection = pika.BlockingConnection(pika.ConnectionParameters(host='47.111.87.61', port=5672, credentials=credentials))
channel = connection.channel()

# 声明队列
channel.queue_declare(queue='HELLOP')
channel.basic_qos(prefetch_count=1)  #限制未处理消息的最大值

# 定义一个回调函数,当获得消息时,Pika库调用这个回调函数来处理消息
def callback(ch, method, properties, body):
    # ch.basic_ack(delivery_tag=method.delivery_tag)  # ack机制,
    print("receive message", body.decode())


channel.basic_consume(
    "HELLOP",
    callback,  # 回调地址(函数)
    auto_ack=False # True自动ack机制,告诉队列完成了,反之则需要手动告诉队列完成了
)

# 等待消息
channel.start_consuming()
  1. 实验:
      开启了两个消费者,同时开启ack机制,发布五个任务,发现一个消费者接受的任务为1 3 5另一个则是2 4,则说明在不使用交换机fanout模式下,消费者是均匀的向发布者拿取数据的
      设置一个消费者channel.basic_qos(prefetch_count=1) 即开启客户端最大的未处理消息队列大小为1,并将这个消费者ack机制关闭,并且不手动告诉队列这个任务完成,发布五个任务,这个消费者只接收了一个数据,其余四个都跑到了另外一个消费者手中,由此我们知道了channel.basic_qos(prefetch_count=1)的用法
    4. 注意:basic_qos自动应答的情况下这两个值是不生效的
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值