21.6. 配置 WS-RM Persistence


概述

本章中已描述的 Apache CXF WS-RM 功能为网络故障等情况提供了可靠性。WS-RM 持久性在其他类型的故障之间提供可靠性,如 RM 源或 RM 目的地崩溃。

WS-RM 持久性涉及将各种 RM 端点的状态存储在持久性存储中。这可让端点在重新发送时继续发送和接收信息。

Apache CXF 在配置文件中启用 WS-RM 持久性。默认的 WS-RM 持久性存储是基于 JDBC。为方便起见,Apache CXF 包括用于开箱即用部署的 Derby。此外,持久存储也使用 Java API 公开。要实施自己的持久性机制,您可以将这个 API 与首选 DB 搭配使用。

重要

WS-RM 持久性仅支持单向调用,它默认是禁用的。

它如何工作

Apache CXF WS-RM 持久性可以正常工作:

  • 在 RM 源端点上,传出消息会在传输前保留。在收到确认后,它会从持久性存储中驱除。
  • 恢复崩溃后,它会恢复保留的消息并重新传输,直到所有消息都已确认。此时,RM 序列关闭。
  • 在 RM 目的地端点上,会保留传入的消息,并在成功存储后发送确认。成功分配消息时,它会从持久性存储中驱除。
  • 从崩溃中恢复后,它会恢复保留的消息并发送它们。它还会将 RM 序列进入接受、确认和发送新消息的状态。

启用 WS-persistence

要启用 WS-RM 持久性,您必须为 WS-RM 指定实施持久性存储的对象。您可以自行开发,也可以使用 Apache CXF 附带的基于 JDBC 的存储。

例 21.14 “配置默认 WS-RM Persistence 存储” 中显示的配置启用了 Apache CXF 附带的基于 JDBC 的存储。

例 21.14. 配置默认 WS-RM Persistence 存储

<bean id="RMTxStore" class="org.apache.cxf.ws.rm.persistence.jdbc.RMTxStore"/>
<wsrm-mgr:rmManager id="org.apache.cxf.ws.rm.RMManager">
    <property name="store" ref="RMTxStore"/>
</wsrm-mgr:rmManager>

配置 WS-persistence

Apache CXF 附带的基于 JDBC 的存储支持 表 21.4 “JDBC 存储属性” 中显示的属性。

表 21.4. JDBC 存储属性
属性名称类型默认设置

driverClassName

字符串

org.apache.derby.jdbc.EmbeddedDriver

userName

字符串

null

passWord

字符串

null

url

字符串

jdbc:derby:rmdb;create=true

例 21.15 “为 WS-RM 持久性配置 JDBC 存储” 中显示的配置启用了 Apache CXF 附带的基于 JDBC 的存储,同时将 driverClassNameurl 设置为非默认值。

例 21.15. 为 WS-RM 持久性配置 JDBC 存储

<bean id="RMTxStore" class="org.apache.cxf.ws.rm.persistence.jdbc.RMTxStore">
    <property name="driverClassName" value="com.acme.jdbc.Driver"/>
    <property name="url" value="jdbc:acme:rmdb;create=true"/>
</bean>
Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

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

让开源更具包容性

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

關於紅帽

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

© 2024 Red Hat, Inc.