事务与容器管理全解析
1. 事务访问与管理
1.1 事务访问方式
事务可以通过 OSGi 的 DataSourceFactory
来访问,具体是调用 DataSourceFactory.createXADataSource()
方法。之后,为每个独立的关系型数据库管理系统(RDBMS)获取一个 XAConnection
。
1.2 事务启动与关联
启动事务是通过调用 TransactionManager.begin()
方法实现的。一旦调用该方法,事务就会立即开始,并与当前线程关联。可以通过调用 TransactionManager.getTransaction()
来获取这个新事务,但需要注意的是,必须在最初启动事务的线程中调用该方法。
需要强调的是,一个事务在同一时间只能在一个线程的上下文中执行。因为如果多个线程同时为同一个事务执行操作,就无法确定操作的顺序。
1.3 资源登记与事务执行
使用 Transaction
对象,可以将所有想要参与全局事务的资源进行登记,在这个例子中,这些资源就是由变量 xaConn1
和 xaConn2
表示的 RDBMS。之后就可以执行跨数据库的更新语句。当两个更新都成功完成后,调用当前全局事务的 commit()
方法来结束事务。这里需要注意的是,只需要调用一次 commi