精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Spring事務傳播性的相關知識

OSC開源社區 ? 來源:vivo互聯網技術 ? 2024-01-10 09:29 ? 次閱讀

作者:vivo 互聯網服務器團隊 - Zhou Shaobin

本文主要介紹了Spring事務傳播性的相關知識。

Spring中定義了7種事務傳播性:

PROPAGATION_REQUIRED

PROPAGATION_SUPPORTS

PROPAGATION_MANDATORY

PROPAGATION_REQUIRES_NEW

PROPAGATION_NOT_SUPPORTED

PROPAGATION_NEVER

PROPAGATION_NESTED

在Spring環境中,含有事務的方法嵌套調用,事務是如何傳遞的規則,以及每種規則是如何開展工作的。文章還提到每種事務傳播性是如何使用的,方便讀者依據實際的場景,使用不同的事務規則。

一、什么是Spring事務的傳播性

Spring 事務傳播性是指, 在Spring的環境中,當多個含有事務的方法嵌套調用時,每個事務方法都處于自己事務的上下文中,其提交或者回滾行為應該如何處理。

通俗講,就是當一個事務方法調用另外一個事務方法時,事務如何跨上下文傳播。

cf2af760-aee1-11ee-8b88-92fbcf53809c.jpg

1)當事務方法A調用事務方法B時,事務方法B是合并到事務方法A中,還是開啟新事務?

2)當事務方法B拋出異常時 ,在合并事務或者開啟新的事務的場景中,事務的回滾是如何處理的 ?

以上事務的處理規則,都取決于事務傳播級別的設置。

二、事務的傳播性都有哪些行為

cf2ee46a-aee1-11ee-8b88-92fbcf53809c.jpg

事務的傳播行為,主要分為三種類型,分別是:支持當前事務不支持當前事務嵌套事務

2.1 支持當前事務

REQUIRED:默認的事務傳播級別,表示如果當前方法已在事務內,該方法就在當前事務中執行,否則,開啟一個新的事務并在其上下文中執行。

SUPPORTED:當前方法在事務內,則在其上下文中執行該方法,否則,開啟一個新的事務。

MANDATORY:必須在事務中執行,否則,將拋出異常。

2.2 不支持當前事務

REQUIRES_NEW:無論當前是否有事務上下文,都會開啟一個事務 。如果已經有一個事務在執行 ,則正在執行的事務將被掛起 ,新開啟的事務會被執行。

事務之間相互獨立,互不干擾。

NOT_SUPPORTED:不支持事務,如果當前存在事務上下文,則掛起當前事務,然后以非事務的方式執行。

NEVER:不能在事務中執行,如果當前存在事務上下文,則拋出異常。

2.3嵌套事務

NESTED:嵌套事務,如果當前已存在一個事務的上下文中,則在嵌套事務中執行,如果拋異常,則回滾嵌套事務,而不影響其他事務的操作。

三、每種事務的傳播性如何工作

3.1 REQUIRED

默認的事務傳播行為,保證多個嵌套的事務方法在同一個事務內執行,并且同時提交,或者出現異常時,同時回滾。

這個機制可以滿足大多數業務場景。

cf396f52-aee1-11ee-8b88-92fbcf53809c.jpg

例子 :

cf421346-aee1-11ee-8b88-92fbcf53809c.jpg

cf4c16ca-aee1-11ee-8b88-92fbcf53809c.jpg

1)類TestAService的方法通過聲明式事務的方式,加上了事務注解@Transactional ,并設置事務的傳播性為REQUIRED。

2)調用者調用TestAService的A方法時,如果調用者沒有開啟事務,那么A方法會開啟一個事務。

A方法的具體執行過程如下 :

a. 執行insert,但沒有提交;

b.調用TestBServcie的B方法,由于B方法也聲明了事務,并且傳播性是REQUIRED,所以方法B的事務,合并到方法A開啟的事務中。

c.方法B執行insert操作,此時也沒有提交。

3)由于這兩個方法的操作都在同一個事務中執行,當這兩個方法所有操作執行成功之后,提交事務。

嵌套調用鏈路:

cf4fd530-aee1-11ee-8b88-92fbcf53809c.jpg

當方法B 執行時拋出了 Exception 異常后,事務是如何處理的 ?

1)方法B聲明了事務,insert操作會回滾

2)由于方法A和方法B 同屬一個事務,方法A也會執行回滾,由此說明該規則保證了事務的原子性。

嵌套調用,異常后的鏈路:

cf544d90-aee1-11ee-8b88-92fbcf53809c.jpg

如果 方法B 拋出異常后,方法A 使用 try-catch 處理了方法B的異常(如下代碼),并沒有向外拋出,此時事務又如何處理的 ?

cf661444-aee1-11ee-8b88-92fbcf53809c.jpg

方法A也會回滾。

從事務的特性我們可知,事務具有原子性。方法A和方法B同屬一個事務,當方法B拋出異常,觸發回滾操作后,整個事務的操作都會回滾。

因此,Spring 在處理事務過程中,當事務的傳播性設置為REQUIRED,在整個事務的調用鏈上,任何一個環節拋出的異常都會導致全局回滾。

3.2 REQUIRES_ NEW

每次都開啟一 個新的事務。

cf71346e-aee1-11ee-8b88-92fbcf53809c.jpg

例子:

cf74b526-aee1-11ee-8b88-92fbcf53809c.jpg

上面例子中,方法B的傳播性設置為 REQUIRES_NEW,方法A仍然是REQUIRED,當A調用B時,具體調用鏈路如下:

cf78fb4a-aee1-11ee-8b88-92fbcf53809c.jpg

具體執行過程:

方法A被執行前,如果調用者沒有開啟事務,方法A開啟一個事務1,然后執行insert ,此時沒有提交;

方法B的事務傳播性設置為REQUIRES_NEW,當被方法A調用時,此時方法A的事務1會被掛起,方法B開啟自己的事務2,然后執行insert,此時并沒有提交;

當方法B執行完畢后,提交事務2;

恢復事務1,最終提交。

當 方法B 執行時拋出了異常,會發生什么?

方法B的insert操作會被回滾掉,方法A不受影響。但這里有個前提,方法A需要try-catch方法B的異常,使其異常不會往上傳遞,從而導致方法A接收到異常,導致回滾。

cf8e0e4a-aee1-11ee-8b88-92fbcf53809c.jpg

3.3 SUPPORTED

當外層方法A存在事務,方法B加入到當前事務中,以事務的方式執行。

cf9203ba-aee1-11ee-8b88-92fbcf53809c.jpg

當外層方法A不存在事務,方法B不會創建新的事務,以非事務的方式執行。

cf959822-aee1-11ee-8b88-92fbcf53809c.jpg

例子1:

cf99f494-aee1-11ee-8b88-92fbcf53809c.jpg

cf9d6eee-aee1-11ee-8b88-92fbcf53809c.jpg

以上例子,方法A沒有加事務注解,方法B的加了事務注解,并且傳播為SUPPORTS。

具體執行過程:

方法A以非事務的方式執行insert操作。

方法B被調用,由于其外層事務A沒有開啟事務,方法B也是以非事務方法執行insert操作。

cfa1c642-aee1-11ee-8b88-92fbcf53809c.jpg

例子2:

cfa58354-aee1-11ee-8b88-92fbcf53809c.jpg

以上例子,方法A和B都加上了事務注解,其中方法A的傳播性為REQUIRED,方法B的傳播性為SUPPORTS。

具體執行過程:

如果方法A的調用方沒有開啟事務,則方法A開啟事務,并執行insert操作,但沒有提交;

方法B被調用,由于其外層方法A開啟了事務,因此方法B加入到方法A開啟的事務中,并執行insert,但沒有提交;

當事務中的所有操作執行成功后,事務提交。

cfadd6d0-aee1-11ee-8b88-92fbcf53809c.jpg

3.4 NOT_SUPPORTED

不支持事務。

如果外層方法存在事務,則掛起外層事務,以非事務方式執行,執行完畢后,恢復外層事務。

cfb82f36-aee1-11ee-8b88-92fbcf53809c.jpg

例子:

cfbbb3f4-aee1-11ee-8b88-92fbcf53809c.jpg

以上例子:方法A和B都加上了事務注解,方法A的傳播性為REQUIRED,方法B為NOT_SUPPORTED。

具體執行過程:

如A的調用方沒有開啟事務,方法A開啟事務,并執行insert,但沒有提交。

方法A調用方法B時,方法B的傳播性為NOT_SUPPORTED,不支持事務,然后掛起外層方法A的事務,方法B以非事務的方式執行insert。

方法B執行完畢后,恢復方法A的事務,最終提交事務。

調用鏈路過程:

cfbf87cc-aee1-11ee-8b88-92fbcf53809c.jpg

3.5 NEVER

不支持事務

當外層方法A開啟了事務,方法B拋出異常

cfcb8202-aee1-11ee-8b88-92fbcf53809c.jpg

例子:

cfd572ee-aee1-11ee-8b88-92fbcf53809c.jpg

以上代碼,兩個方法都打上了事務注解,方法A的傳播性是REQUIRED,方法B的傳播性是NEVER。

具體執行過程:

方法A開啟事務,執行insert,沒有提交。

含有事務的方法A調用方法B,方法B的傳播性是NEVER,表示不支持事務,因此方法B拋出異常。

方法A的事務執行回滾。

cfdba3bc-aee1-11ee-8b88-92fbcf53809c.jpg

3.6 MANDATORY

必須在事務中執行。

如果外層方法A沒有開啟事務,方法B拋出異常。

cfe68804-aee1-11ee-8b88-92fbcf53809c.jpg

如果外層方法A開啟了事務,方法B加入事務,方法A&B在同一事務中執行。

cfee5322-aee1-11ee-8b88-92fbcf53809c.jpg

例子:

cffb49ce-aee1-11ee-8b88-92fbcf53809c.jpg

以上例子,方法A沒有加事務注解,方法B 的傳播性為 MANDATORY。

具體執行過程:

方法A的調用方如果本身沒有開啟事務,方法A執行前不會開啟事務。

當非事務方法A調用方法B時,由于方法B的傳播性為MANDATORY,必須在事務中執行,條件不滿足,拋出異常。

cfff335e-aee1-11ee-8b88-92fbcf53809c.jpg

3.7 NESTED

嵌套事務

如果外層方法A不存在事務,內層方法B的規則與REQUIRED 一致。

如果外層方法A存在事務,內層方法B做為外層方法A事務的子事務執行,兩個方法是一起提交,但子事務是獨立回滾。

內層方法B拋出異常,則會回滾方法B的所有操作,但不影響外層事務方法A。(方法A需要try-catch子事務,避免異常傳遞到父層事務)

外層方法A回滾,則內層方法B也會回滾。

該傳播性的特點是可以保存狀態點,當回滾時,只會回滾到某一個狀態點,保證了子事務之間的獨立性,避免嵌套事務的全局回滾。

d0034e76-aee1-11ee-8b88-92fbcf53809c.jpg

例子:

d012ff38-aee1-11ee-8b88-92fbcf53809c.jpg

以上例子,方法A的傳播性為REQUIRED,方法B為NESTED。

具體執行過程:

方法A執行時,如調用方沒有開啟事務,則開啟一個事務。

方法B被外層方法A調用時,因為方法B的傳播性為NESTED,方法B在此處建立savepoint,標記insert行為。

當方法B拋出異常,其insert操作會回滾,但只會回滾到savepoint,(前提是方法A要try-catch方法B,使方法B的異常不會往外傳遞)。

方法B回滾后,方法A的事務提交。

調用鏈路:

d02ed262-aee1-11ee-8b88-92fbcf53809c.jpg

四、總結

本文解釋了Spring框架中的事務傳播性,即多個業務方法之間調用時事務如何處理的規則。Spring提供了七種傳播級別,如

PROPAGATION_REQUIRED、

PROPAGATION_REQUIRES_NEW等。

每種級別都有適用場景和限制,本文提供了一些示例,介紹了聲明式事務如何使用,每種事務的規則,產生哪種行為,當方法拋出異常時,事務的提交和回滾是如何被處理的。正確處理事務對于任何企業級應用程序都是必要的,了解Spring事務傳播性是構建高效、可靠和可擴展應用程序的關鍵。

審核編輯:湯梓紅

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 互聯網
    +關注

    關注

    54

    文章

    11105

    瀏覽量

    103012
  • 服務器
    +關注

    關注

    12

    文章

    9020

    瀏覽量

    85182
  • spring
    +關注

    關注

    0

    文章

    338

    瀏覽量

    14308

原文標題:Spring七種事務傳播性介紹

文章出處:【微信號:OSC開源社區,微信公眾號:OSC開源社區】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Spring事務失效的十種常見場景

    Spring的聲明式事務功能更是提供了極其方便的事務配置方式,配合Spring Boot的自動配置,大多數Spring Boot項目只需要在
    的頭像 發表于 12-11 15:03 ?861次閱讀

    Spring事務實現原理

    作者:京東零售 范錫軍 1、引言 springspring-tx模塊提供了對事務管理支持,使用spring事務可以讓我們從復雜的
    的頭像 發表于 11-08 10:10 ?735次閱讀
    <b class='flag-5'>Spring</b><b class='flag-5'>事務</b>實現原理

    什么是java spring

    什么是java springSpring是一個開源框架,它由Rod Johnson創建。它是為了解決企業應用開發的復雜而創建的。Spring使用基本的JavaBean來完成以前只可能由EJB完成
    發表于 09-11 11:16

    Spring的兩種方式事務管理和API接口介紹

    Spring事務管理
    發表于 03-21 06:52

    Spring事務分析的實現方式

    Spring事務原理分析
    發表于 07-02 15:19

    詳解Spring事務管理

    在學習spring事務管理時,我忍不住要問,spring為什么進行事務管理,spring怎么進行的事務
    發表于 07-12 06:54

    Spring事務管理詳解說明

    Spring事務管理詳解
    發表于 05-20 13:46

    spring中聲明式事務實現原理猜想

    ? @Transactional注解簡介 @Transactional 是spring中聲明式事務管理的注解配置方式,相信這個注解的作用大家都很清楚。 @Transactional 注解可以幫助
    的頭像 發表于 10-13 09:20 ?1612次閱讀

    淺談Spring事務的那些坑

    對于從事java開發工作的同學來說,spring事務肯定再熟悉不過了。在某些業務場景下,如果同時有多張表的寫入操作,為了保證操作的原子(要么同時成功,要么同時失敗)避免數據不一致的情況,我們一般都會使用
    的頭像 發表于 10-11 10:31 ?722次閱讀

    發現一個Spring事務的巨坑bug 你必須要小心了

    1.錯誤的訪問權限 2.方法被定義成final的 3.方法內部調用 4.當前實體沒有被spring管理 5.錯誤的spring事務傳播特性 6.數據庫不支持
    的頭像 發表于 10-11 18:17 ?836次閱讀

    淺談Spring事務底層原理

    開啟Spring事務本質上就是增加了一個Advisor,但我們使用@EnableTransactionManagement注解來開啟Spring事務是,該注解代理的功能就是向
    的頭像 發表于 12-06 09:56 ?672次閱讀

    Spring Boot Web相關的基礎知識

    Boot的第一個接口。接下來將會將會介紹使用Spring Boot開發Web應用的相關內容,其主要包括使用spring-boot-starter-web組件來實現Web應用開發、URL地址映射、參數傳遞、數據校驗規、統一數據返
    的頭像 發表于 03-17 15:03 ?623次閱讀

    Spring事務在哪幾種情況下會不生效?

    日常開發中,我們經常使用到spring事務。最近星球一位還有去美團面試,被問了這么一道面試題: Spring 事務在哪幾種情況下會不生效?
    的頭像 發表于 05-10 17:53 ?897次閱讀
    <b class='flag-5'>Spring</b><b class='flag-5'>事務</b>在哪幾種情況下會不生效?

    8個Spring事務失效的場景介紹

    作為Java開發工程師,相信大家對Spring事務的使用并不陌生。但是你可能只是停留在基礎的使用層面上,在遇到一些比較特殊的場景,事務可能沒有生效,直接在生產上暴露了,這可能就會導致比較嚴重的生產
    的頭像 發表于 05-11 10:41 ?598次閱讀
    8個<b class='flag-5'>Spring</b><b class='flag-5'>事務</b>失效的場景介紹

    spring事務失效的一些場景

    對于從事java開發工作的同學來說,spring事務肯定再熟悉不過了。 在某些業務場景下,如果一個請求中,需要同時寫入多張表的數據。為了保證操作的原子(要么同時成功,要么同時失敗),避免數據
    的頭像 發表于 10-08 14:27 ?424次閱讀
    <b class='flag-5'>spring</b><b class='flag-5'>事務</b>失效的一些場景