源碼分析:Spring 事務(wù) @Transactional Timeout 參數(shù)不生效的問題

本文通過分析Spring 事務(wù)的源碼,說明@Transactional Timeout 參數(shù)設(shè)置的一些問題。

從問題開始誓琼,下面兩段代碼油湖,事務(wù)是否都能正常的回滾巍扛?

timeout 參數(shù)大于3

代碼片段1

    @Transactional(rollbackFor = Exception.class , propagation = Propagation.REQUIRED,timeout = 3)
    public int timeout(int timeout,int blogId){
        jdbcTemplate.execute("DELETE FROM blog where id = "+blogId);
        Sleep.second(timeout);
        jdbcTemplate.execute("SELECT 1");
        return timeout;
    }

代碼片段2

    @Transactional(rollbackFor = Exception.class , propagation = Propagation.REQUIRED,timeout = 3)
    public int timeout(int timeout , int blogId){
        jdbcTemplate.execute("DELETE FROM blog where id = "+blogId);
        Sleep.second(timeout);
        return timeout;
    }

按照我們的認(rèn)知,上面的代碼都應(yīng)該因?yàn)槌瑫r(shí)拋出異常從而觸發(fā) rollback ,但是實(shí)際運(yùn)行結(jié)果是 代碼片段2 不會回滾乏德,如果在生產(chǎn)環(huán)境意味著數(shù)據(jù)會真實(shí)的被刪除撤奸。

帶著問題來看源碼

  1. 首先我們從Timeout的異常堆棧追蹤到異常拋出的代碼
1.png
  1. 定位到ResourceHolderSupport#checkTransactionTimeout 方法,查看源碼
2.png

通過源碼可以看到喊括,源碼通過一個(gè) dealline (Date) 與當(dāng)前時(shí)間比較來判斷是否超時(shí)胧瓜,那么這會就產(chǎn)生了兩個(gè)疑問:

  • dealline 在哪里設(shè)置的?
  • 什么時(shí)候調(diào)用checkTransactionTimeout?
  1. 跟蹤 dealline 屬性,找到設(shè)置的方法 ResourceHolderSupport#setTimeoutInMillis,通過Debug面板郑什,追蹤調(diào)用堆棧府喳,可以定位到DataSourceTransactionManager#doBegin方法
3.png
  1. 查看 DataSourceTransactionManager#doBegin 方法,定位到設(shè)置timeout的代碼端蘑拯,到這里我們第一個(gè)問題得到了答案


    4.png
  2. 通過ResourceHolderSupport#checkTransactionTimeout堆棧找到調(diào)用方法

    • DataSourceUtils#applyTimeout
    • JdbcTemplate#applyStatementSettings
  • JdbcTemplate#execute
5.png
6.png
7.png

從這里就能清楚的知道钝满, checkTransactionTimeout 是在每次執(zhí)行SQL的時(shí)候被調(diào)用的,這也就能說明為什么代碼片段1可以正城恳龋回滾了舱沧,因?yàn)榇a片段1在最后執(zhí)行了一條無意義的SQL “SELECT 1” 觸發(fā)了 checkTransactionTimeout 的檢查。

整個(gè)檢查過程抽象為流程圖就是下面這樣

process.png

本文源碼地址

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末偶洋,一起剝皮案震驚了整個(gè)濱河市熟吏,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌玄窝,老刑警劉巖牵寺,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異恩脂,居然都是意外死亡帽氓,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進(jìn)店門俩块,熙熙樓的掌柜王于貴愁眉苦臉地迎上來黎休,“玉大人,你說我怎么就攤上這事玉凯∈迫” “怎么了?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵漫仆,是天一觀的道長捎拯。 經(jīng)常有香客問我,道長盲厌,這世上最難降的妖魔是什么署照? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任祸泪,我火速辦了婚禮,結(jié)果婚禮上建芙,老公的妹妹穿的比我還像新娘没隘。我一直安慰自己,他們只是感情好岁钓,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布升略。 她就那樣靜靜地躺著,像睡著了一般屡限。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上炕倘,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天钧大,我揣著相機(jī)與錄音,去河邊找鬼罩旋。 笑死啊央,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的涨醋。 我是一名探鬼主播瓜饥,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼浴骂!你這毒婦竟也來了乓土?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤溯警,失蹤者是張志新(化名)和其女友劉穎趣苏,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體梯轻,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡食磕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了喳挑。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片彬伦。...
    茶點(diǎn)故事閱讀 39,722評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖伊诵,靈堂內(nèi)的尸體忽然破棺而出单绑,到底是詐尸還是另有隱情,我是刑警寧澤日戈,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布询张,位于F島的核電站,受9級特大地震影響浙炼,放射性物質(zhì)發(fā)生泄漏份氧。R本人自食惡果不足惜唯袄,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蜗帜。 院中可真熱鬧恋拷,春花似錦、人聲如沸厅缺。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽湘捎。三九已至诀豁,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間窥妇,已是汗流浹背舷胜。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留活翩,地道東北人烹骨。 一個(gè)月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像材泄,于是被迫代替她去往敵國和親沮焕。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評論 2 353

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