rabitmq-consumer-nextDelivery

阅读更多

QueueingConsumer consumer = new QueueingConsumer(channel);

声明一个消费者,然后接收消息。

 

如果我们直接用这种方式:consumer.nextDelivery()

那么当这个consumer没有消息时,线程会阻塞。因为consumer内部是blockqueue,没有数据却取数据时,就会阻塞,知道有数据放进此blockqueue中。

 

除非你知道这个consumer会接收到多少条消息,就调用多少次的consumer.nextDelivery(),不过这总是不可靠的。

那么你可以这样用:

consumer.nextDelivery(TIMEOUT)

 

 

你可能感兴趣的:(rabitmq-consumer-nextDelivery)