26.19. PAYLOAD 模式中的流支持
camel-cxf 组件现在支持在使用 PAYLOAD 模式时流传输传入的信息。在以前的版本中,传入的信息会完全解析 DOM。对于大型消息,这非常耗时,并且使用了大量内存。在路由时,传入的消息可以保留为 javax.xml.transform.Source,如果没有修改有效负载,则可以直接流传输到目标目的地。对于常见的"simple proxy"用例(例如: from ("cxf:…").to ("cxf:…"),这可能会造成非常显著的性能增加,并显著降低了内存要求。
然而,在有些情况下,流可能不合适或需要。由于流性质,在处理链中稍后之前,无效的传入 XML 可能无法被发现。此外,某些操作可能需要通过 DOM 解析消息,如 WS-Security 或消息追踪等,在这种情况下,流的优势有限。此时,可以通过两种方式控制流:
- endpoint 属性:您可以添加 "allowStreaming=false" 作为端点属性,以打开流 on/off。
- 组件属性:CxfComponent 对象也有一个 allowStreaming 属性,可以为从该组件创建的端点设置默认值。
全局系统属性:您可以将 "org.apache.camel.component.cxf.streaming" 的系统属性添加到 "false" 以将其关闭。这会设置全局默认值,但设置上面的 endpoint 属性将覆盖该端点的此值。