Spring注解事務(wù)詭異提交全面解析

一俏蛮、問題產(chǎn)生背景

應(yīng)用上線的時(shí)候撑蚌,正常調(diào)用Tomcat的shutdown.sh腳本,事務(wù)執(zhí)行一半異常提交搏屑。偽代碼如下:

@Override
    @Transactional(propagation = Propagation.REQUIRED)
    public void insert(PaymentOrder paymentOrder) {
        try{
            paymentOrderDao.update(paymentOrder);
            PaymentOrderDao.insert(paymentOrder)
        }catch(Exception e){
            logger.error(" 操作支付訂單失敗 biz " + paymentOrder.getBiz() + " bizOrder " + paymentOrder.getBizOrder(), e);
            Throw e;
        }
    }

上面是一段偽代碼锨并,實(shí)際在tomcat重啟的時(shí)候,上面update語句提交睬棚,而insert沒有第煮。

二、思路解析

1抑党、直接將Tomcat服務(wù)kill掉能否重現(xiàn)問題
按之前的理解是包警,Tomcat重啟事務(wù)中斷,數(shù)據(jù)庫在事務(wù)連接超時(shí)后會回滾事務(wù)底靠。那么寫一段代碼試一下害晦,使用Kill -9命令中斷tomcat服務(wù)后發(fā)現(xiàn)數(shù)據(jù)庫事務(wù)竟然回滾了。

2暑中、分析Tomcat的shutdown.sh命令
其實(shí)shutdown.sh命令最終調(diào)用的是catalina.sh命令腳本壹瘟,看sh源碼如下:

exec "$_RUNJAVA" $JAVA_OPTS $CATALINA_OPTS \
    -Djava.endorsed.dirs="$JAVA_ENDORSED_DIRS" -classpath "$CLASSPATH" \
    -Dcatalina.base="$CATALINA_BASE" \
    -Dcatalina.home="$CATALINA_HOME" \
    -Djava.io.tmpdir="$CATALINA_TMPDIR" \
    org.apache.catalina.startup.Bootstrap "$@" stop

其實(shí)最終是調(diào)用的Bootstrap這個(gè)類來關(guān)閉服務(wù)的,我們再來看這個(gè)類的內(nèi)容鳄逾。

if (server instanceof Lifecycle) { 
            try { 
               ((Lifecycle) server).stop(); 
            } catch (LifecycleException e) { 
                log.error("Catalina.stop", e); 
            } 
        }

Tomcat是將注冊進(jìn)來的服務(wù)循環(huán)逐個(gè)關(guān)閉稻轨,這時(shí)候在關(guān)閉的時(shí)候可能會因?yàn)榍耙粋€(gè)資源關(guān)閉而造成后一個(gè)資源拋出異常,注意這個(gè)異常有可能是Throwable雕凹,也可能是Exception殴俱,后面詳細(xì)解釋。

3枚抵、分析Spring注解事務(wù)源碼

Paste_Image.png

在Tomcat關(guān)閉的時(shí)候线欲,拋出的異常和上面代碼的異常沒有匹配成功,spring異常匹配采用迭代當(dāng)前異常的所有父類與目標(biāo)異常匹配汽摹,匹配不到后檢查當(dāng)前異常是否為Error或者RuntimeException的實(shí)例,是的話也能匹配上李丰,但是沒有匹配是否為Throwable的實(shí)例

三、問題總結(jié)

通過上面的問題分析逼泣,可以把代碼寫成如下樣式:

@Override
    @Transactional(rollbackFor = Throwable.class, propagation = Propagation.REQUIRED)
    public void insert(PaymentOrder paymentOrder) {
        try{
            paymentOrderDao.update(paymentOrder);
            PaymentOrderDao.insert(paymentOrder)
        }catch(Throwable e){
            logger.error(" 操作支付訂單失敗 biz " + paymentOrder.getBiz() + " bizOrder " + paymentOrder.getBizOrder(), e);
            Throw e;
        }
    }

采用Throwable捕獲方能確保Tomcat異常重啟趴泌,事務(wù)能夠正確回滾。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末圾旨,一起剝皮案震驚了整個(gè)濱河市踱讨,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌砍的,老刑警劉巖痹筛,帶你破解...
    沈念sama閱讀 223,002評論 6 519
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡帚稠,警方通過查閱死者的電腦和手機(jī)谣旁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,357評論 3 400
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來滋早,“玉大人榄审,你說我怎么就攤上這事「唆铮” “怎么了搁进?”我有些...
    開封第一講書人閱讀 169,787評論 0 365
  • 文/不壞的土叔 我叫張陵,是天一觀的道長昔头。 經(jīng)常有香客問我饼问,道長,這世上最難降的妖魔是什么揭斧? 我笑而不...
    開封第一講書人閱讀 60,237評論 1 300
  • 正文 為了忘掉前任莱革,我火速辦了婚禮,結(jié)果婚禮上讹开,老公的妹妹穿的比我還像新娘盅视。我一直安慰自己,他們只是感情好旦万,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,237評論 6 398
  • 文/花漫 我一把揭開白布闹击。 她就那樣靜靜地躺著,像睡著了一般纸型。 火紅的嫁衣襯著肌膚如雪拇砰。 梳的紋絲不亂的頭發(fā)上梅忌,一...
    開封第一講書人閱讀 52,821評論 1 314
  • 那天狰腌,我揣著相機(jī)與錄音,去河邊找鬼牧氮。 笑死琼腔,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的踱葛。 我是一名探鬼主播丹莲,決...
    沈念sama閱讀 41,236評論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼尸诽!你這毒婦竟也來了甥材?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,196評論 0 277
  • 序言:老撾萬榮一對情侶失蹤性含,失蹤者是張志新(化名)和其女友劉穎洲赵,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,716評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡叠萍,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,794評論 3 343
  • 正文 我和宋清朗相戀三年芝发,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片苛谷。...
    茶點(diǎn)故事閱讀 40,928評論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡辅鲸,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出腹殿,到底是詐尸還是另有隱情独悴,我是刑警寧澤,帶...
    沈念sama閱讀 36,583評論 5 351
  • 正文 年R本政府宣布锣尉,位于F島的核電站绵患,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏悟耘。R本人自食惡果不足惜落蝙,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,264評論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望暂幼。 院中可真熱鬧筏勒,春花似錦、人聲如沸旺嬉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,755評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽邪媳。三九已至捐顷,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間雨效,已是汗流浹背迅涮。 一陣腳步聲響...
    開封第一講書人閱讀 33,869評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留徽龟,地道東北人叮姑。 一個(gè)月前我還...
    沈念sama閱讀 49,378評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像据悔,于是被迫代替她去往敵國和親传透。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,937評論 2 361

推薦閱讀更多精彩內(nèi)容

  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,869評論 6 342
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法极颓,類相關(guān)的語法朱盐,內(nèi)部類的語法,繼承相關(guān)的語法菠隆,異常的語法兵琳,線程的語...
    子非魚_t_閱讀 31,669評論 18 399
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理骚烧,服務(wù)發(fā)現(xiàn),斷路器闰围,智...
    卡卡羅2017閱讀 134,720評論 18 139
  • //Clojure入門教程: Clojure – Functional Programming for the J...
    葡萄喃喃囈語閱讀 3,688評論 0 7
  • 老婆: 有一個(gè)事必須和你說清楚赃绊,就是所謂的四月十二日,我說過我絕不會有什么事瞞著你羡榴,所以請你相信碧查。 其實(shí)我想了很久...
    曉曉石頭閱讀 208評論 0 0