18.18. PAYLOAD 模式中的流支持


camel-cxf 组件现在在使用 PAYLOAD 模式时支持流传输传入的消息。在以前的版本中,传入的信息会被完全解析。对于大型消息,这会消耗时间,并使用大量内存。传入消息可以在路由时保留为 javax.xml.transform.Source,如果没有修改有效负载,则可以直接流传输到目标目的地。对于常见的"简单代理"用例(例如: from ("cxf:…​").to ("cxf:…​")),这可提供显著的性能增加,并显著降低的内存要求。

然而,在有些情况下,流可能不合适或需要。由于流性质,在处理链中稍后才会发现无效的传入的 XML。此外,某些操作可能需要消息成为 DOM 解析任何方法(如 WS-Security 或消息追踪等),在这种情况下,流的优点有限。此时,可以通过两种方式控制流:

  • endpoint 属性:您可以添加 "allowStreaming=false" 作为端点属性,以打开 streaming on/off。
  • 组件属性: CxfComponent 对象也有一个 allowStreaming 属性,可为从该组件创建的端点设置默认。

全局系统属性: 您可以将"org.apache.camel.component.cxf.streaming"的系统属性添加到 "false" 以将其关闭。这会设置全局默认值,但设置上述 endpoint 属性将覆盖该端点的值。

Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

© 2024 Red Hat, Inc.