項目進行讀寫分離及分庫分表,在一個業(yè)務中,在一個事務中處理時候?qū)⑶袚Q多個數(shù)據(jù)源,需要保證同一事務多個數(shù)據(jù)源數(shù)據(jù)的一致性。

        此處使用atomikos來實現(xiàn)(附源碼)。另外需要注意以下:

       1:spring3.0之后不再支持jtom[jta]了,支持第三方開源軟件atomikos(http://www.atomikos.com/)來實現(xiàn). 
       2:org.springframework.transaction.jta.JotmFactoryBean類,spring-tx-2.5.6.jar中有此類,spring-tx-3.0.0.RELEASE.jar之后沒有此類。
       3:atomikos事務控制框架,其中看到有3種數(shù)據(jù)源,分別是,SimpleDataSourceBean,AtomikosDataSourceBean,AtomikosNonXADataSourceBean。
            1、SimpleDataSourceBean: 這個是最簡單地數(shù)據(jù)源配置,需要配置XA驅(qū)動。
            2、AtomikosDataSourceBean:  分布式數(shù)據(jù)源,Atomikos實現(xiàn)的數(shù)據(jù)源,需要配置XA驅(qū)動,推薦此配置,可以配置連接池的信息。
            3、AtomikosNonXADataSourceBean: 非分布式數(shù)據(jù)源,該數(shù)據(jù)源配置需要普通JDBC的驅(qū)動,可以配置連接池:
       4:Atomikos支持XA(全局事務)和NON-XA(非全局事務),NON-XA[nonxadatasource]效率高于XA。XA事務往往是包括多個數(shù)據(jù)源的全局事務,非XA是單個數(shù)據(jù)源的.
       5:XA連接是一個JTA事務中的參與者。XA連接不支持JDBC的自動提交特性。也就是說應用程序不必在xa

網(wǎng)友評論