此版本仍在开发中,尚未被视为稳定版本。对于最新的稳定版本,请使用 spring-cloud-stream 4.1.4! |
错误通道
从版本 1.3 开始,Binder 无条件地将异常发送到每个 Consumer 目标的错误通道,并且还可以配置为将异步 producer send failures发送到 error 通道。 有关更多信息,请参阅“错误处理”。
RabbitMQ 有两种类型的发送失败:
-
返回的消息、
-
否定确认 发行商确认。
后者很少见。
根据 RabbitMQ 文档,“[A nack] 只有在负责队列的 Erlang 进程中发生内部错误时才会交付。
如果您使用reject-publish
queue overflow 行为。
除了启用 producer 错误通道(如“错误处理”中所述)之外,RabbitMQ Binder 仅在连接工厂配置适当时才向通道发送消息,如下所示:
-
ccf.setPublisherConfirms(true);
-
ccf.setPublisherReturns(true);
将 Spring Boot 配置用于连接工厂时,请设置以下属性:
-
spring.rabbitmq.publisher-confirms
-
spring.rabbitmq.publisher-returns
的ErrorMessage
对于返回的消息,是一个ReturnedAmqpMessageException
具有以下属性:
-
failedMessage
: spring-messagingMessage<?>
未能发送。 -
amqpMessage
:原始 spring-amqpMessage
. -
replyCode
:一个整数值,指示失败的原因(例如,312 - 无路由)。 -
replyText
:指示失败原因的文本值(例如,NO_ROUTE
). -
exchange
:消息发布到的 Exchange。 -
routingKey
:发布消息时使用的路由密钥。
另请参阅 Publisher Confirms 以获取接收返回消息的替代机制。
对于否定确认的确认,有效负载是NackedAmqpMessageException
具有以下属性:
-
failedMessage
: spring-messagingMessage<?>
未能发送。 -
nackReason
:原因(如果可用 — 您可能需要检查代理日志以了解更多信息)。
不会自动处理这些异常(例如发送到死信队列)。 您可以在自己的 Spring 集成流中使用这些异常。