一个参数
channel.basicQos(1); //basicQos(int prefetchCount)
两个参数
channel.basicQos(3,false); //basicQos(int prefetchCount, boolean global)
三个参数
channel.basicQos(0,3,false); //basicQos(int prefetchSize, int prefetchCount, boolean global)
prefetchSize:可接收消息的大小的
prefetchCount:处理消息最大的数量。举个例子,如果输入1,那如果接收一个消息,但是没有应答,则客户端不会收到下一个消息,消息只会在队列中阻塞。如果输入3,那么可以最多有3个消息不应答,如果到达了3个,则发送端发给这个接收方得消息只会在队列中,而接收方不会有接收到消息的事件产生。总结说,就是在下一次发送应答消息前,客户端可以收到的消息最大数量。
global:是不是针对整个Connection的,因为一个Connection可以有多个Channel,如果是false则说明只是针对于这个Channel的
例子
一个生产者一次性生产20条消息,两个消费者,QosConsumerMain,QosConsumerMain2,将两个消费者的prefetchCount值设置成5,QosConsumerMain没有进行ack,而QosConsumerMain2进行了ack,结果如下
结论:prefetchCount为配置设置的值5,意味着每个消费者每次会预取5个消息准备消费。
备注:prefetchSize 和global这两项,实际过程中几乎不使用,参数设不设置几乎没有硬性并且rabbitmq没有实现,暂且不做讨论。rabbitmq后期更新了这两项参数,后期再分享使用经验。