![](/img/trans.png)
[英]Spring AMQP Rabbit - single consumer listening to multiple queues - what is the delivery order?
[英]Catching exceptions from Spring AMQP Rabbit Consumer
我正在尝试使用本教程创建 RPC 服务。
我想捕捉异常。 当前,当doJob
引发异常时,生产者会收到超时异常,并且该异常未记录在服务器上的控制台上。
我尝试使用container.setErrorHandler
,但没有结果。 如何在生产者和消费者中捕获异常?
我是说
public String doJob(int clientId) {
String uuid = UUID.randomUUID().toString();
log.info("UUID {} generated on node {} upon request from client {}", uuid, nodeId, clientId);
return uuid;
}
可以返回异常。 我怎样才能在这部分抓住它们:
String payload = proxy.doJob(clientId);
log.info("Client {} received payload: {}", clientId, payload);
Thread.sleep(2000);
您正在使用带有异步消息传递的请求/响应模式。 因此,生产者和消费者在逻辑上是分开的。 这种分离是明确的,因为它有很多好处。 这是异步消息传递的基本原则。
消费者抛出的异常不会通过消息代理传播回发送消息的生产者。 这将破坏客户的逻辑分离。
生产者的超时异常表明消费者出现问题,导致其无法返回响应。 由于生产者和消费者的逻辑分离,生产者永远不会知道为什么会发生超时异常。 同样,这是设计使然。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.