JavaEE事務(wù)掃盲筆記之一掃掃到尾

          1.資料

          2.本地事務(wù)與分布式事務(wù)

          • 本地事務(wù)
            完全依賴于DB、JMS自身,,如直接調(diào)用jdbc中的conn.commit();這里沒應(yīng)用服務(wù)器什么事,所以也不支持多數(shù)據(jù)源的全局事務(wù)。
          • 分布式事務(wù)
            在JavaEE世界的事務(wù)在JTA、JTS規(guī)范和XA Sources之上實(shí)現(xiàn)。
            JTA是用戶編程接口,JTS是服務(wù)器底層服務(wù),兩者一般由應(yīng)用服務(wù)器自帶實(shí)現(xiàn),而atomikos 、JOTM 和JBoss Transaction 是專門搞局搶生意的。
            XA Sources其實(shí)先于JavaEE而存在,JDBC driver必須有javax.sql.XADataSource接口的實(shí)現(xiàn)類,否則所謂二階段提交就是個(gè)偽能力。
            JavaEE除了支持JDBC和JMS外,還引入了JCA模型。JCA可以說是目前唯一可移植的插入JavaEE事務(wù)的資源模型,因此像JDO這類框架/Server就是靠乖乖出自己的JCA連接器來參與JavaEE事務(wù)的。

          3.編程式模型

              手工調(diào)用jdbc的connection事務(wù)方法和使用JTA接口都屬于編程式開發(fā),在EJB中叫BMT(Bean管理事務(wù))。
              JTA最重要的接口就是UserTransaction和它的六個(gè)方法-begin,commit,rollback,getStatus,setRollbackonly,setTransactionTimeout。
              程序需要UserTransaction時(shí)可以從JNDI領(lǐng)取,不過JNDI名隨應(yīng)用服務(wù)器不同而不同。EJB3里可以直接用個(gè)@Resource注入。

          4.宣告式模型

              前面都是鋪墊,這個(gè)才是主打的事務(wù)模型,如EJB的CMT(容器管理事務(wù))和Sprin。

              其中EJB2.0,Spring1.0在部署描述符和applicationContext.xml中定義,而EJB3.0和Spring2.0則采用annotation。

          4.1 事務(wù)類型

               這里JavaEE與Spring的定義基本相同:

          • Required:如果Context中有事務(wù)就加入,沒有就自己創(chuàng)建一個(gè)。(最常用設(shè)置)
          • Mandatory:永遠(yuǎn)加入一個(gè)事務(wù)。如果當(dāng)前Context沒有事務(wù),拋出異常。(那些不打算自己負(fù)責(zé)rollback事務(wù)的方法,必須加入到別人的事務(wù),由別人來控制rollback)
          • RequiresNew:永遠(yuǎn)新建一個(gè)事務(wù)。(那些不管別人如何,自己必須提交事務(wù)的方法,比如審計(jì)信息是一定要寫的)
          • Supports:如果有事務(wù)就加入,如果沒有就算了。永遠(yuǎn)不會(huì)創(chuàng)建新事務(wù)。(一般用于只讀方法,不會(huì)主動(dòng)創(chuàng)建事務(wù),但如果當(dāng)前有事務(wù)就加入,以讀到事務(wù)中未提交的數(shù)據(jù))
          • NotSupported:永遠(yuǎn)不使用事務(wù),如果當(dāng)前有事務(wù),掛起事務(wù)。(那些有可能拋異常但異常并不影響全局的方法)
          • Never:不能在有當(dāng)前事務(wù)的情況下調(diào)用本方法。(生人勿近?)

                可見,Required是默認(rèn)的設(shè)置,Supports是只讀方法的最佳選擇。

          4.2 事務(wù)隔離級(jí)別

          • ReadUncommited:本事務(wù)可以看到另一事務(wù)未提交的數(shù)據(jù)。臟讀。
          • ReadCommited:本事務(wù)只可以看到另一事務(wù)已提交的數(shù)據(jù)。不可重復(fù)讀。
          • RepeatableRead:可重復(fù)讀。在一個(gè)事務(wù)內(nèi),第一次讀到的數(shù)據(jù),在本事務(wù)沒有提交前,無論另一個(gè)事務(wù)如何提交數(shù)據(jù),本事務(wù)讀到的數(shù)據(jù)都是不變的。
          • Serializable:串行化,同時(shí)只有一個(gè)事務(wù)能讀相同的數(shù)據(jù)。

              級(jí)別越低越安全效率也越低。隔離級(jí)別需要相關(guān)資源支持,如重復(fù)讀在Oracle里會(huì)降級(jí)為ReadCommited。Spring里默認(rèn)的Default級(jí)別完全看數(shù)據(jù)源的臉色行事。

          4.3 關(guān)于Rollback

              EJB里,想rollback只能sessionContext.setRollbackOnly(),或者拋出EJBException。(EJB3還可以annotation設(shè)置某些自定義Exception可以觸發(fā)rollback)

              在Spring里,同樣只會(huì)rollback unchecked exception(RuntimeExcption及子類),而checked exception(Exception及子類)是不會(huì)rollback的,除非你特別聲明。

             @Transactional(readOnly = false, propagation = Propagation.REQUIRES_NEW,rollbackFor = {MyException1.class,MyException2.class})

              因此所有在service層方法中用throws定義的Exception,都必須在事務(wù)定義中進(jìn)行rollback設(shè)定。(請(qǐng)勿善忘)

              所有在service層方法中c被atch處理了的異常,又希望容器輔助rollback的話,必須重拋一個(gè)預(yù)定義的RuntimeException的子類。(請(qǐng)勿回望)

          4.4 關(guān)于Spring

              Spring不希望編程式事務(wù)管理。
              Spring也不希望使用EJB CMT--CMT依賴于EJB而無法用于POJO,依賴于JTA全局事務(wù)對(duì)單數(shù)據(jù)源場(chǎng)景造成了浪費(fèi),而且rollback機(jī)制比較麻煩(必須為EJBException或手工setRollbackOnly())。
              因此Spring通過AOP實(shí)現(xiàn)了對(duì)POJO的整套宣告式事務(wù)體系;對(duì)jdbc,hibernate,jpa,jms等local數(shù)據(jù)源和JTA實(shí)現(xiàn)了統(tǒng)一的事務(wù)管理機(jī)制,而且支持本地資源與JTA在配置文件級(jí)的切換,而且改進(jìn)了rollback機(jī)制。

             1)一個(gè)本地事務(wù)管理器:

          <bean id="transactionManager"  class="org.springframework.orm.jpa.JpaTransactionManager">  <property name="entityManagerFactory" ref="entityManagerFactory" /> </bean>

             2)Spring就會(huì)把請(qǐng)求都轉(zhuǎn)發(fā)到應(yīng)用服務(wù)器的JTA對(duì)象上(注意此時(shí)數(shù)據(jù)源也需要改為用JNDI從應(yīng)用服務(wù)器獲取)。

          <bean id="myTxManager" class="org.springframework.transaction.jta.JtaTransactionManager"/>

             3)應(yīng)用服務(wù)器專有的類型的JTA事務(wù)管理器:

          <bean id="myTxManager" class="org.springframework.transaction.jta.WebLogicJtaTransactionManager"/>

          posted on 2008-01-11 09:44 靈! 閱讀(390) 評(píng)論(0)  編輯  收藏 所屬分類: Java專題-系統(tǒng)架構(gòu)


          只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


          網(wǎng)站導(dǎo)航:
           
          <2008年1月>
          303112345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          導(dǎo)航

          統(tǒng)計(jì)

          隨筆分類

          隨筆檔案

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          主站蜘蛛池模板: 铜陵市| 鲁山县| 青海省| 肥城市| 舒兰市| 文昌市| 偃师市| 博乐市| 邹平县| 玉林市| 阳曲县| 什邡市| 莒南县| 措勤县| 阿尔山市| 宜阳县| 铅山县| 临沭县| 濮阳县| 株洲市| 永州市| 惠安县| 潜山县| 赞皇县| 保山市| 平度市| 林甸县| 峨眉山市| 翁源县| 嘉荫县| 习水县| 太仓市| 海丰县| 嘉峪关市| 泰和县| 宜都市| 义马市| 南溪县| 洛川县| 堆龙德庆县| 准格尔旗|