Distributed/Global Transaction Management
>> It uses "2pc"(2 phase commit) protocol by involving multiple resources(eg. database) in a single transaction boundary.
2pc Protocol responsibility
>> 2pc protocol asks all databases if it can commit or not. If all databases reply yes then all databases data are committed. If any databases rises any error or exception then all databases rolled back the transaction as show below...>> For this we need to use XA jdbc drivers, XA datasources and XA databases.
>> Oracle all versions, Mysql 5.x onwards are XA databases
>> To perform distributed/global transaction management, we use JTATransactionManager by supplying distributed transaction object and transaction service object.
>> We can get these 2, distributed transaction object and transaction service object from Jndi registry of application server or by using third party apis like Atomikos, Narayana etc..
JTATransactionManager example using Atomikos API
>> If application is standalone, it is recommended to use third party apis like Atomikos, Narayana etc..
>> If application is a web application, it is recommended to use Server Managed transaction..
Post a Comment