This chapter describes how WebLogic Server participates in distributed transactions coordinated by third-party systems (referred to as foreign transaction managers). The WebLogic Server processing occurs as part of the work of the external transaction. The foreign transaction manager then drives the WebLogic Server transaction manager as part of its commit processing. This is referred to as "importing" transactions into WebLogic Server.
This chapter includes the following sections:
Importing Transactions with the Client Interposed Transaction Manager
Importing Transactions with the Server Interposed Transaction Manager
The WebLogic Server transaction manager exposes a javax.transaction.xa.XAResource implementation using the weblogic.transaction.InterposedTransactionManager interface. A foreign transaction manager can access the InterposedTransactionManager interface to coordinate the WebLogic Server transaction manager XAResource during its commit processing.
When importing a transaction from a foreign transaction manager into the WebLogic Server transaction manager, you must register the WebLogic Server interposed transaction manager (ITM) as a subordinate with the foreign transaction manager. The WebLogic Server transaction manager then acts as the coordinator for the imported transaction within WebLogic Server.
WebLogic Server supports two configuration schemes for importing transactions:
Using a client-side gateway (implemented externally to WebLogic Server) that uses the client interposed transaction manager
Using a server-side gateway implemented on a WebLogic Server instance that uses the server interposed transaction manager
Although there are some differences in limitations and in implementation details, the basic behavior is the same for importing transactions in both configurations:
Lookup the WebLogic Server transaction manager and register it as an XAResource as necessary in the third-party system.
Enlist and delist applicable transaction participants during transaction processing.
Send the prepare message to the WebLogic Server transaction manager, which then acts as a subordinate transaction manager and coordinates the prepare phase for transaction participants within WebLogic Server.
Send the commit or roll back message to the WebLogic Server transaction manager, which then acts as a subordinate transaction manager and coordinates the second phase of the two-phase commit process for transaction participants within WebLogic Server.
Unregister, as necessary.
You can use the client interposed transaction manager in WebLogic Server to drive the two-phase commit process for transactions that are coordinated by a third-party transaction manager and include transaction participants within WebLogic Server, such as JMS resources and JDBC resources. The client interposed transaction manager is an implementation of the javax.transaction.xa.XAResource interface. You access the client interposed transaction manager directly from the third-party application, typically from a gateway in the third-party application. The transaction manager in the third-party system then sends the prepare and commit messages to the gateway, which propagates the message to the WebLogic Server transaction manger. The WebLogic Server transaction manager then acts as a subordinate transaction manager and coordinates the transaction participants within WebLogic Server. Figure 14-1 shows the interaction between the two transaction managers and the client-side gateway.
Figure 14-1 Importing Transactions into WebLogic Server Using a Client-Side Gateway

Figure 14-2 shows the flow of interactions between a foreign transaction manager, WebLogic Server client-side JTA objects, and the WebLogic Server transaction manager.
Figure 14-2 State Diagram Illustrating Steps to Import a Transaction Using the Client Interposed Transaction Manager

To access the interposed transaction manager in WebLogic Server using a client-side gateway, you must perform the following steps:
In a client-side gateway, the you can get the WebLogic server interposed transaction manager's XAResource with the getClientInterposedTransactionManager method. For example:
import javax.naming.Context; import weblogic.transaction.InterposedTransactionManager; import weblogic.transaction.TxHelper; Context initialCtx; String serverName; InterposedTransactionManager itm = TxHelper.getClientInterposedTransactionManager(initialCtx, serverName);
The server name parameter is the name of the server that acts as the interposed transaction manager for the foreign transaction. When the foreign transaction manager performs crash recovery, it must contact the same WebLogic Server server to obtain the list of in-doubt transactions that were previously imported into WebLogic Server.
For more information, see weblogic.transaction.TxHelper in the Java API Reference for Oracle WebLogic Server.
After you get the interposed transaction manager, you must get the XAResource object associated with the interposed transaction manager:
import javax.transaction.xa.XAResource; XAResource xar = itm.getXAResource();
You can configure cluster-wide transaction recovery of distributed transactions across all the interposed transaction managers of a cluster by selecting the Enable Cluster-Wide Recovery attribute on the "Cluster: Configuration: JTA" page in the Oracle WebLogic Server Administration Console Online Help.
When enabled, each interposed transaction manager in a WebLogic cluster is aware of the transaction distribution across the entire cluster. This allows the interposed transaction manager on each cluster member to determine if it should handle a given XA call or forward it to the appropriate interposed transaction manager on another cluster member. In addition:
An XAResource.recover call on a single ITM within a WebLogic cluster returns a list of in-doubt transactions of all interposed transaction manager 's within the cluster.
If a cluster member fails, the interposed transaction manager is migrated to another cluster member within the same cluster.
If a WebLogic distributed destination is present on a cluster, messages could be load balanced to other cluster members other than the member hosting the interposed transaction manager. If this occurs, the interposed transaction manager transparently handles any XA calls and forwards them to the correct cluster member instance. In the situation that the cluster member that hosts the destination fails. The interposed transaction manager transparently handles the potential failover of that destination member.
You can use the server interposed transaction manager in WebLogic Server to drive the two-phase commit process for transactions that are coordinated by a third-party transaction manager and include transaction participants within WebLogic Server, such as JMS resources and JDBC resources. The server interposed transaction manager is an implementation of the javax.transaction.xa.XAResource interface. You access the server interposed transaction manager by creating a server-side gateway on WebLogic Server and then accessing the gateway from a third-party system. The transaction manager in the third-party system then sends the prepare and commit messages to the server-side gateway, which propagates the message to the WebLogic Server transaction manager. The WebLogic Server transaction manager then acts as a subordinate transaction manager and coordinates the transaction participants within WebLogic Server. Figure 14-3 shows the interaction between the two transaction managers and the server-side gateway.
Figure 14-3 Importing Transactions into WebLogic Server Using a Server-Side Gateway

To access the interposed transaction manager in WebLogic Server using a server-side gateway, you must perform the following steps:
In a server-side gateway, you can get the interposed transaction manager's XAResource as follows:
import javax.naming.Context; import weblogic.transaction.InterposedTransactionManager; import weblogic.transaction.TxHelper; InterposedTransactionManager itm = TxHelper.getServerInterposedTransactionManager();
For more information, see weblogic.transaction.TxHelper in the Java API Reference for Oracle WebLogic Server.
After you get the interposed transaction manager, you must get the XAResource. See Get the XAResource from the Interposed Transaction Manager.
Note the following limitations when importing transactions using a server-side gateway:
Do not use the TxHelper.getClientInterposedTransactionManager() method in a server-side gateway on a WebLogic Server server. Doing so causes performance issues.
You can only use one WebLogic Server server interposed transaction manager at a time. Do not use multiple server interposed transaction managers (on the same thread) to import transactions at the same time. (See Transaction Processing for Imported Transactions for more information about this limitation and how transactions are processed with the WebLogic Server interposed transaction manager.)
To import a foreign transaction into WebLogic Server, the foreign transaction manager or gateway can do the following:
xar.start(foreignXid, TMNOFLAGS);
This operation associates the current thread with the imported transaction. All subsequent calls made to other servers propagate the imported WebLogic Server transaction, until the transaction is disassociated from the thread.
Note:
The flag is ignored by the WebLogic Server transaction manager. If the foreign Xid has been imported previously on the same WebLogic Server server, WebLogic Server associates the current thread with the previously imported WebLogic Server transaction.To disassociate the imported transaction from the current thread, the foreign transaction manager or gateway should do the following:
xar.end(foreignXid, TMSUCCESS);
Note that the WebLogic Server transaction manager ignores the flag.
Note the following processing limitations and behavior for imported transactions:
After a WebLogic Server transaction is started, the gateway cannot call start again on the same thread. With a client-side gateway, you can only call xar.start on one client interposed transaction manager at a time. Attempting to call xar.start on another client interposed transaction manager (before xar.end was called on the first one) throws an XAException with XAER_RMERR. With a server-side gateway, attempting to call xar.start on a client or server interposed transaction manager also throws a XAException with XAER_RMERR if there is an active transaction associated with the current thread.
The WebLogic Server interposed transaction manager's XAResource exhibits loosely-coupled transaction branching behavior on different WebLogic Server servers. That is, if the same foreign Xid is imported on different WebLogic Server servers, they are imported to different WebLogic Server transactions.
The WebLogic Server transaction manager does not flatten the transaction tree, for example, the imported transaction of a previously exported WebLogic Server transaction are in a separate branch from the original WebLogic Server transaction.
A foreign transaction manager should ensure that all foreign Xids that are imported into WebLogic Server are unique and are not reused within the sum of the transaction abandon timeout period and the transaction timeout period. Failure to do so may result in log records that are never released in the WebLogic Server transaction manager. This could lead to inefficient crash recovery.
The foreign transaction manager should drive the interposed transaction manager in the 2PC protocol as it does the other XAResources. Note that the beforeCompletion callbacks registered with the WebLogic Server JTA (for example, the EJB container) are called when the foreign transaction manager prepares the interposed transaction manager's XAResource. The afterCompletion callbacks are called during XAResource.commit or XAResource.rollback.
The WebLogic Server interposed transaction manager honors the XAResource contract as described in the Java Transaction API at http://www.oracle.com/technetwork/java/javaee/jta/index.html.
Once prepared by a foreign transaction manager, the WebLogic Server interposed transaction manager waits persistently for a commit or rollback outcome from the foreign transaction manager until the transaction abandon timeout expires.
The WebLogic Server interposed transaction manager remembers heuristic outcomes persistently until being told to forget about the transaction by the foreign transaction manager or until transaction abandon timeout.
The WebLogic Server transaction manager logs a prepare record for the imported transaction after all the WebLogic Server participants are successfully prepared. If there are multiple WebLogic Server participants for the imported transaction, the transaction manager logs a prepare record even if the XAResource.commit is a one-phase commit.
During the crash recovery of the foreign transaction manager, the foreign transaction manager must get the XAResource of the WebLogic Server interposed transaction manager again, and call recover on it. The WebLogic Server interposed transaction manager then returns the list of prepared or heuristically completed transactions. The foreign transaction manager should then resolve those in-doubt transactions: either commit or rollback the prepared transactions, and call forget on the heuristically completed transactions.
You can configure tight coupling of transaction branches that span different transaction manager systems by selecting the Enable Tightly Coupled Transactions attribute on the "Cluster: Configuration: JTA" page in the Oracle WebLogic Server Administration Console Online Help.
When the Enable Tightly Coupled Transactions attribute is enabled, WebLogic Server uses the transaction identifier of a transaction imported by the interposed transaction manager for XA calls rather than an internally mapping a transaction id. This tighter coupling of transaction managers typically improves performance and applies to inter-domain WebLogic transactions and transactions imported from Tuxedo.
Notes:
Oracle does not support tightly coupled transactions with other external transaction processing systems for which interoperability is enabled using WSAT. However, for EJBs and applications within a single cluster that uses the same transaction id, tight coupling can be enabled. For more information about WSAT, see "Using Web Services Atomic Transactions" in Developing JAX-WS Web Services for Oracle WebLogic Server.
If a transaction between WebLogic and Tuxedo resources uses a GridLink Data Source with GridLink Affinity enabled, the XA Affinity context is automatically used for the transaction.