rabitmq-consumer-nextDelivery

QueueingConsumer consumer = new QueueingConsumer(channel);

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

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

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

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

那么你可以这样用:

consumer.nextDelivery(TIMEOUT)

扫描二维码关注公众号,回复: 468724 查看本文章

猜你喜欢

转载自joandora.iteye.com/blog/2260685