假设RabbitMQ服务器有上万条未处理消息,随便打开一个消费端,会形成巨量消息瞬间所有推送过来,然而咱们单个客户端没法同时处理这么多数据。java
还好比说单个Pro一分钟产生了几百条数据,可是单个Con一分钟可能只能处理60条,这时Pro-Con不平衡。一般Pro没办法作限制,因此Con就须要作一些限流措施,不然若是超出最大负载,可能致使Con性能降低,服务器卡顿甚至崩溃。服务器
所以,咱们须要Con限流。markdown
RabbitMQ提供了一种qos (服务质量保证)功能,在非自动确认消息的前提下,若必定数目的消息 (经过基于Con或者channel设置Qos的值) 未被确认前,不消费新的消息。性能
不能设置自动签收功能(autoAck = false) 若是消息未被确认,就不会到达Con,目的就是给Pro减压fetch
请求特定设置“服务质量(quality of service)”。 这些设置强加数据的服务器将须要确认以前,为消费者发送的消息数量限制。 所以,他们提供消费者发起的流量控制的一种手段。 ui
void BasicQos(uint prefetchSize, ushort prefetchCount, bool global);
复制代码
prefetchSize和global这两项,RabbitMQ没有实现,不研究 prefetchCount在
autoAck=false
的状况下生效,即在自动应答的状况下该值无效,因此必须手工ACK。spa
void basicAck(Integer deliveryTag,boolean multiple) 复制代码
调用该方法就会主动回送给Broker一个应答,表示这条消息我处理完了,你能够给我下一条了。参数multiple表示是否批量签收,因为咱们是一次处理一条消息,因此设置为false。code