如何使用rabbitmq java客户端从队列中检索unack消息

时间:2014-08-05 14:36:39

标签: java client rabbitmq recover

我正在寻找一种方法来检索unack消息并将它们恢复到就绪状态,以便我的消费者可以再次发回这些消息。 enter image description here

我正在使用java客户端来获取消息,这些是我发送和检索消息的编程。我读到有一个方法basicRecover(),它会将消息放回队列中。

SendMessage
ConnectionFactory factory = new ConnectionFactory();
factory.setHost("localhost");
Connection connection = factory.newConnection();
Channel channel = connection.createChannel();

channel.queueDeclare(QUEUE_NAME, true, false, false, null);
for(int i=0;i<1000;i++)
{
    String message = "message goes here";

    channel.basicPublish("", QUEUE_NAME, null, message.getBytes());
    System.out.println(" [x] Sent '" + message + "'");
}
channel.close();
connection.close();

}

Retrieve
try
    {
        ConnectionFactory factory = new ConnectionFactory();
        factory.setHost("10.4.4.19");
        factory.setUsername("test");
        factory.setPassword("test");
            //factory.setPort(5267);
        connection=factory.newConnection();
        channel=connection.createChannel();
        channel.basicQos(1);
        QueueingConsumer consumer = new QueueingConsumer(channel);
        channel.basicConsume(QUEUE_NAME, false, consumer);

        for(int i=0;i<1;i++)
        {
            QueueingConsumer.Delivery delivery = consumer.nextDelivery();
            String message = new String(delivery.getBody());
            System.out.println(" [x] Received '" + message + "'");
           // Thread.currentThread().sleep(3000);
            channel.basicAck(delivery.getEnvelope().getDeliveryTag(), false);

        }
        channel.close();
        connection.close();
    }
    catch(Exception e)
    {
        System.out.println("Error:"+e.getMessage());
        e.printStackTrace();
    }

任何人都可以为我提供一个代码片段,以便unack消息可以恢复到就绪状态,我可以使用我的检索编程来读取它们。

1 个答案:

答案 0 :(得分:1)

如果您不执行channel.basicAck(delivery.getEnvelope().getDeliveryTag(), false);,则会(最终)重新传递该消息。您不必告知服务该消息未被传递,它对委托人有效,即任何未被确认为已交付的内容未送达。

http://pubs.vmware.com/vfabric5/index.jsp?topic=/com.vmware.vfabric.rabbitmq.2.4/tutorials/tutorial-two-java.html

但正如您将在上面的链接中读到的那样,取消确认消息的唯一方法是终止/关闭服务连接。