当路由中发生异常并且未被异常管理器捕获时,将显示路由的详细信息,帮助我们了解可能出现的问题。
捕获并管理异常时,如何才能拥有相同类型的日志?
我希望从java部分获得一些“可调用的”,例如在处理器中,但是dsl风格的东西也可以。
路线记录通常如下:
Message History
---------------------------------------------------------------------------------------------------------------------------------------
RouteId ProcessorId Processor Elapsed (ms)
[route1 ] [cxf_process ] [cxfrs://bean:myServer?bindingStyle=SimpleConsumer ] [ 60029]
[route1 ] [to55 ] [direct:validateAndRedirect ] [ 60029]
[route27 ] [setProperty37 ] [setProperty[operationName] ] [ 0]
[route27 ] [setProperty38 ] [setProperty[Country] ] [ 0]
[route27 ] [setProperty39 ] [setProperty[Language] ] [ 0]
[route27 ] [process25 ] [my.package.ExtractUserMailProcessor@535f9aac ] [ 0]
[route27 ] [enrich25 ] [enrich[direct:checkAccess] ] [ 0]
[route27 ] [recipientList1 ] [recipientList[simple{Simple: direct:${property.operationName}}] ] [ 60029]
[route28 ] [setHeader84 ] [setHeader[CamelCxfRsUsingHttpAPI] ] [ 0]
[route28 ] [setHeader85 ] [setHeader[CamelHttpPath] ] [ 0]
[route28 ] [setHeader86 ] [setHeader[CamelHttpMethod] ] [ 1]
[route28 ] [setHeader87 ] [setHeader[Content-Type] ] [ 0]
[route28 ] [enrich9 ] [enrich[direct:wsClient] ] [ 60029]
[route7 ] [to7 ] [cxfrs:bean:myClient ] [ 60027]
Exchange
---------------------------------------------------------------------------------------------------------------------------------------
...
提前,
弗朗索瓦
答案 0 :(得分:4)
这是消息历史EIP模式
该页面详细介绍了这一点,以及您如何自己访问历史记录。 org.apache.camel.util.MessageHelper#dumpMessageHistoryStacktrace
是Camel用来输出您在上面看到的表格的原因。
但正如Konstantin上面所写,您可以从Java代码访问历史记录,如下所示
List<MessageHistory> list = exchange.getProperty(Exchange.MESSAGE_HISTORY, List.class);
答案 1 :(得分:1)
在深入研究代码之后,我找到了org.apache.camel.util.MessageHelper#dumpMessageHistoryStacktrace,它应该做我想做的事。