如何停止从选择队列消费消息 - RabbitMQ

13
QueueingConsumer consumer = new QueueingConsumer(channel);
System.out.println(consumer.getConsumerTag());
channel.basicConsume("queue1", consumer);
channel.basicConsume("queue3", consumer);

是否可能动态地停止仅消费来自队列 "queue3" 的消息?

1个回答

31

是的,您可以使用 channel.basicCancel(consumerTag);进行取消。

编辑 例如:

String tag3 = channel.basicConsume("queue3", consumer);
channel.basicCancel(tag3)

在这里,您可以找到一个代码,它会在5秒后取消订阅消费者:

String tag1 = channel.basicConsume(myQueue, autoAck, consumer);
String tag2 = channel.basicConsume(myQueue2, autoAck, consumer);
    executorService.execute(new Runnable() {
        @Override
        public void run() {
            while (true) {
                Delivery delivery;
                try {
                    delivery = consumer.nextDelivery();
                    String message = new String(delivery.getBody());
                    System.out.println("Received: " + message);
                } catch (Exception ex) {
                    Logger.getLogger(TestMng.class.getName()).log(Level.SEVERE, null, ex);
                }
            }
        }
    });
    System.out.println("Consumers Ready");
    try {
        Thread.sleep(5000);
    } catch (InterruptedException ex) {
        Logger.getLogger(TestMng.class.getName()).log(Level.SEVERE, null, ex);
    }

    channel.basicCancel(tag2); /// here you remove only the Myqueue2

希望它有用。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接