8 Java Transaction API and Oracle WebLogic Extensions
- JTA API Overview
Learn about the JTA API with the help of brief overview. WebLogic Server supports thejavax.transaction
package and thejavax.transaction.xa
package, which implement the Java Transaction API (JTA) for Java applications. - Oracle WebLogic Extensions to JTA
Extensions to the Java Transactions API are provided where the JTA specification does not cover implementation details and where additional capabilities are required.
JTA API Overview
Learn about the JTA API with the help of brief overview. WebLogic Server supports the javax.transaction
package and the javax.transaction.xa
package, which implement the Java Transaction API (JTA) for Java applications.
For more information about JTA, see the Java Transaction API (JTA) Specification published at http://www.oracle.com/technetwork/java/javaee/jta/index.html
. For a detailed description of the javax.transaction
and javax.transaction.xa
interfaces, see the JTA Javadoc.
JTA includes the following components:
-
An interface for demarcating and controlling transactions from an application,
javax.transaction.UserTransaction
. You use this interface as part of a Java client program or within an EJB as part of a bean-managed transaction. -
An interface for allowing a transaction manager to demarcate and control transactions for an application,
javax.transaction.TransactionManager
. This interface is used by an EJB container as part of a container-managed transaction and uses thejavax.transaction.Transaction
interface to perform operations on a specific transaction. -
Interfaces that allow the transaction manager to provide status and synchronization information to an applications server,
javax.transaction.Status
andjavax.transaction.Synchronization
. These interfaces are accessed only by the transaction manager and cannot be used as part of an applications program. -
Interfaces for allowing a transaction manager to work with resource managers for XA-compliant resources (
javax.transaction.xa.XAResource
) and to retrieve transaction identifiers (javax.transaction.xa.Xid
). These interfaces are accessed only by the transaction manager and cannot be used as part of an applications program.
Parent topic: Java Transaction API and Oracle WebLogic Extensions
Oracle WebLogic Extensions to JTA
Extensions to the Java Transactions API are provided where the JTA specification does not cover implementation details and where additional capabilities are required.
Oracle WebLogic provides the following capabilities based on interpretations of the JTA specification:
-
Client-initiated transactions—the JTA transaction manager interface (
javax.transaction.TransactionManager
) is made available to clients and bean providers through JNDI. This allows clients and EJBs using bean-managed transactions to suspend and resume transactions.Note:
A suspended transaction must be resumed in the same server process in which it was suspended.
-
Scope of transactions—transactions can operate within and between clusters and domains.
-
Enhanced
javax.transaction.TransactionSynchronizationRegistry
support—WebLogic Server provides the ability to lookup theTransactionSynchronizationRegistry
object in JNDI using the standard name ofjava:comp/TransactionSynchronizationRegistry
. Oracle extends support by providing two additional global JNDI names:javax/transaction/TransactionSynchronizationRegistry
andweblogic/transaction/TransactionSynchronizationRegistry
. Seejavax.transaction.TransactionSynchronizationRegistry
athttp://docs.oracle.com/javaee/7/api/index.html?javax/transaction/TransactionSynchronizationRegistry.html
.
Oracle WebLogic Server provides the following classes and interfaces as extensions to JTA:
-
weblogic.transaction.RollbackException
(extendsjavax.transaction.RollbackException
)This class preserves the original reason for a rollback for use in more comprehensive exception information.
-
weblogic.transaction.TransactionManager
(extendsjavax.transaction.TransactionManager
)The WebLogic JTA transaction manager object supports this interface, which allows XA resources to register and unregister themselves with the transaction manager on startup. It also allows a transaction to be resumed after suspension.
This interface includes the following methods:
-
registerStaticResource
,registerDynamicResource
, andunregisterResource
-
registerResource
— (new in WebLogic Server 8.1) This method includes support for properties that determine how the resource is controlled by the transaction manager. -
getTransaction
-
forceResume
andforceSuspend
-
begin
-
-
weblogic.transaction.Transaction
(extendsjavax.transaction.Transaction
)The WebLogic JTA transaction object supports this interface, which allows users to get and set transaction properties.
This interface includes the following methods:
-
setName
andgetName
-
addProperties
,setProperty
,getProperty
, andgetProperties
-
setRollbackReason
andgetRollbackReason
-
getHeuristicErrorMessage
-
getXID
andgetXid
-
getStatusAsString
-
getMillisSinceBegin
-
getTimeToLiveMillis
-
isTimedOut
-
-
weblogic.transaction.TransactionHelper
This class enables you to obtain the current transaction manager and transaction. It replaces
TxHelper
.This interface includes the following static methods:
-
getTransaction
-
getUserTransaction
-
getTransactionManager
-
-
weblogic.transaction.TxHelper
(Deprecated, useTransactionHelper
instead)This class enables you to obtain the current transaction manager and transaction.
This interface includes the following static methods:
-
getTransaction
,getUserTransaction
,getTransactionManager
-
status2String
-
-
weblogic.transaction.XAResource
(extendsjavax.transaction.xa.XAResource
)This class provides delistment capabilities for XA resources.
This interface includes the following method:
-
getDelistFlag
-
-
weblogic.transaction.nonxa.NonXAResource
This interface enables resources that do not support the
javax.transaction.xa.XAResource
interface to easily integrate with the WebLogic Server transaction manager. The transaction manager supports a variation of the Last Agent two-phase commit optimization that allows a non-XA resource to participate in a distributed transaction. The protocol issues a two-phase commit to the non-XA resource and uses the result of the operation to base the commit decision for the transaction.
For a detailed description of the WebLogic extensions to the javax.transaction
and javax.transaction.xa
interfaces, see the weblogic.transaction
package summary in the Java API Reference for Oracle WebLogic Server.
Parent topic: Java Transaction API and Oracle WebLogic Extensions