SpringCloud 应用错误处理
有两种类型的应用程序级错误处理。可以在每个绑定订阅中处理错误,或者全局处理程序可以处理所有绑定订阅错误。让我们查看详细信息。
对于每个输入绑定,Spring Cloud Stream创建具有以下语义<destinationName>.errors
的专用错误通道。
<destinationName>
由绑定的名称(例如input
)和组的名称(例如myGroup
)组成。
考虑以下:
spring.cloud.stream.bindings.input.group=myGroup
@StreamListener(Sink.INPUT) // destination name 'input.myGroup' public void handle(Person value) { throw new RuntimeException("BOOM!"); } @ServiceActivator(inputChannel = Processor.INPUT + ".myGroup.errors") //channel name 'input.myGroup.errors' public void error(Message<?> message) { System.out.println("Handling ERROR: " + message); }
在前面的示例中,目标名称为input.myGroup
,专用错误通道名称为input.myGroup.errors
。
@StreamListener批注的使用专门用于定义桥接内部通道和外部目标的绑定。假设目标特定错误通道没有关联的外部目标,则该通道是Spring Integration(SI)的特权。这意味着必须使用SI处理程序注释之一(即@ ServiceActivator,@ Transformer等)定义用于此类目标的处理程序。
如果未指定
group
,则使用匿名组(类似于input.anonymous.2K37rb06Q6m2r51-SPIDDQ
),这不适用于错误处理方案,因为在创建目标之前,您不知道它将是什么。
另外,如果您绑定到现有目的地,例如:
spring.cloud.stream.bindings.input.destination=myFooDestination spring.cloud.stream.bindings.input.group=myGroup
完整的目标名称为myFooDestination.myGroup
,然后专用错误通道名称为myFooDestination.myGroup.errors
。
回到例子...
预订名为input
的通道的handle(..)
方法会引发异常。给定错误通道input.myGroup.errors
的订阅者,所有错误消息均由该订阅者处理。
如果您有多个绑定,则可能需要一个错误处理程序。Spring Cloud Stream 通过将每个单独的错误通道桥接到名为errorChannel
的通道来自动提供对全局错误通道的支持,从而允许单个订阅者处理所有错误,如以下示例所示:
@StreamListener("errorChannel") public void error(Message<?> message) { System.out.println("Handling ERROR: " + message); }
如果错误处理逻辑相同,则与哪个处理程序产生错误无关,这可能是一个方便的选择。
更多建议: