我正在寻找一种方法来检索unack消息并将它们恢复到就绪状态,以便我的消费者可以再次发回这些消息。
我正在使用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消息可以恢复到就绪状态,我可以使用我的检索编程来读取它们。
答案 0 :(得分:1)
如果您不执行channel.basicAck(delivery.getEnvelope().getDeliveryTag(), false);
,则会(最终)重新传递该消息。您不必告知服务该消息未被传递,它对委托人有效,即任何未被确认为已交付的内容未送达。
但正如您将在上面的链接中读到的那样,取消确认消息的唯一方法是终止/关闭服务连接。