Fault Tolerance

Fault Tolerance allows multiple adapter configurations to substitute each other.

When the primary adapter configuration terminates unexpectedly, the token held by the primary configuration is taken over by an adapter configuration in the standby state. In the process of replacement, the standby adapter configuration becomes the primary adapter configuration.

Fault Tolerance is based on the JMS queue. Before enabling Fault Tolerance, you have to define a JMS queue and set the prefetch parameter of the JMS queue to none, and then put several JMS messages in the JMS queue as tokens. The number of tokens corresponds to the number of primary adapter instances.

Note: When a standby adapter configuration becomes a primary adapter configuration, it does not take the instance ID of the original primary adapter configuration that terminated unexpectedly and still has its own instance ID.

When running JMS topic as durable, durable names exist on EMS server for each receiver, regardless if adapter configuration is primary or standby.

The following diagram shows how Fault Tolerance works. At first, configuration 1 and configuration 2 fetch one of the two tokens in the JMS queue respectively. They hold the tokens and process messages as primary instances. Configuration 3 does not fetch tokens and runs in standby state. If configuration 2 terminates unexpectedly, it releases the fetched token. Configuration 3 fetches the token released by configuration 2 and continues to process messages as primary configuration.

Enabling Fault Tolerance

To enable the fault tolerance, set the tibco.sdk.faultTolerance.ems.enabled property to ON, and set SDK fault tolerance properties accordingly.

For more detailed information on the SDK fault tolerance properties, see "SDK Fault Tolerance Properties" in TIBCO ActiveMatrix Adapter for SAP Properties.

You can also configure fault tolerance properties in TIBCO Business Studio and TIBCO Administrator.

Note: When Fault Tolerance is enabled, the following two issues occur:
  • If the number of tokens is more than 1, an exception is thrown in one of the following conditions:
    • The transport type is RVCM.
    • The transport type is JMS and the client ID is set value.
    • The delivery mode is Durable in the Subscription Service and Request-Response Service services.
  • If the a primary EMS server switches to the standby state, all primary adapter configurations that fetch tokens from the primary EMS server restart.
When Fault Tolerance is enabled, the following functionalities are not supported:
  • Inbound transaction where the logical unit of work consisting of one or more RFC/BAPI calls.
  • Inbound transaction where the logical unit of work consisting of one RFC/BAPI call and automatic commit is not enabled.
  • Dynamic client connections to the SAP system from the inbound adapter configuration.