国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

spring事務(wù)處理

李文鵬 / 1732人閱讀

摘要:聲明式事務(wù)管理的事務(wù)管理是通過代理實現(xiàn)的。其中的事務(wù)通知由元數(shù)據(jù)目前基于或注解驅(qū)動。代理對象與事務(wù)元數(shù)據(jù)結(jié)合產(chǎn)生了一個代理,它使用一個實現(xiàn)品配合,在方法調(diào)用前后實施事務(wù)。

JDBC事務(wù)
1.獲取連接 Connection con=DriverManager.getConnection();
2.開啟事務(wù) con.setAutoCommit(true/fase);
3.執(zhí)行CRUD
4.提交事務(wù)或回滾事務(wù) con.commit()/con.rollback()
5.關(guān)閉連接 con.close();
數(shù)據(jù)庫隔離級別
隔離級別             隔離級別的值      導(dǎo)致的問題
Read-uncommitted       0            導(dǎo)致臟讀;
Read-committed         1            避免臟讀,允許不可重復(fù)讀和幻讀
Repeatable-Read        2            避免臟讀、不可重復(fù)讀,允許幻讀
Serializable           3            全部避免

臟讀:一事務(wù)對數(shù)據(jù)進行了修改,但未提交,另一事務(wù)可以讀取到未提交的數(shù)據(jù),如果第一個事務(wù)發(fā)生了回滾,那么第二事務(wù)就讀到了。不可重復(fù)讀:一個事務(wù)中發(fā)生了兩次讀操作,第一次讀操作和第二次操作之間,另外一個事務(wù)對數(shù)據(jù)進行了修改,導(dǎo)致兩次讀的數(shù)據(jù)不一致。幻讀:第一個事務(wù)對一定范圍的數(shù)據(jù)進行批量修改,第二個事務(wù)在這個范圍內(nèi)增加一條數(shù)據(jù),這時候第一個事務(wù)就會丟失對新數(shù)據(jù)的修改。
spring事務(wù)的傳播性

事務(wù)傳播性就定義在多個事務(wù)同時存在的時候,spring應(yīng)該如何處理這些事務(wù)的行為,以事務(wù)嵌套為例,來深入理解spring事務(wù)傳播的機制;
假設(shè):外層事務(wù)servicea的methoda()調(diào)用內(nèi)層service的methodb()若spring的級別為:propagation_required(spring的默認值)。如果serviceb.methodb()的事務(wù)級別定位為propagation_required,那么執(zhí)行servicea.methoda()的時候,spring已經(jīng)發(fā)起了事務(wù),這時調(diào)用serviceb.methodb(),serviceb.methodb()看到自己已經(jīng)運行在servicea.methoda()的事務(wù)內(nèi)部,就不再起新的事務(wù)。假設(shè)serviceb.methodb()運行的時候發(fā)現(xiàn)自己沒有在事務(wù)中,他就會為自己分配一個事務(wù)。這樣,在servicea.methoda()或者serviceb.methodb()內(nèi)的任何地方出現(xiàn)異常,事務(wù)都會被回滾。

全局事務(wù)和本地事務(wù)

所謂的全局事務(wù)也可以理解為分布式事務(wù),也就是說程序需要處理來自不同的數(shù)據(jù)庫連接;

所謂的本地事務(wù)可以理解為應(yīng)用程序不需要處理分布式的數(shù)據(jù)庫集群,只處理單一的數(shù)據(jù)源。

spring的關(guān)鍵抽象

spring事務(wù)抽象中的關(guān)鍵是,事務(wù)策略的概念,這個概念由org.springframework.transcation.PlatformTransactionManager接口定義。使用spring時,無論選擇編程式事務(wù)管理,還是聲明式事務(wù)管理,都必須定義一個正確的PlatformTransactionManager實現(xiàn)。舉例如下所示:


    

通過創(chuàng)建事務(wù)管理器,就可將應(yīng)用連接到不同的事務(wù)源上。

spring使用資源同步的事務(wù)

通過配置事務(wù)管理器,我們將應(yīng)用連接到了不同的事務(wù)源上,接下來我們需要直接或間接地獲取一種持久化api(jdbc等)的應(yīng)用代碼,來獲取或操作資源以實現(xiàn)事務(wù)的同步。

spring提供了兩種解決方案,一種是高層抽象的解決方案即對所有持久化API都采用這種 模板 方法,包括 JdbcTemplate、HibernateTemplate和JdoTemplate類,另外一種是低層的解決方案,有以下這些類:DataSourceUtils(針對JDBC),SessionFactoryUtils(針對Hibernate),PersistenceManagerFactoryUtils(針對JDO)等等。

當對應(yīng)用代碼來說,直接同原始持久化API特有的資源類型打交道是更好的選擇時,這些類確保應(yīng)用代碼獲取到正確的Spring框架所管理的bean,事務(wù)被正確同步,處理過程中的異常被映射到一致的API。

spring聲明式事務(wù)管理

Spring的事務(wù)管理是通過AOP代理實現(xiàn)的。 其中的事務(wù)通知由元數(shù)據(jù)(目前基于XML或注解)驅(qū)動。 代理對象與事務(wù)元數(shù)據(jù)結(jié)合產(chǎn)生了一個AOP代理,它使用一個PlatformTransactionManager 實現(xiàn)品配合TransactionInterceptor,在方法調(diào)用前后實施事務(wù)。

舉例說明:

    // 我們想做成事務(wù)性的服務(wù)接口

    package x.y.service;
    
    public interface FooService {
    
      Foo getFoo(String fooName);
    
      Foo getFoo(String fooName, String barName);
    
      void insertFoo(Foo foo);
    
      void updateFoo(Foo foo);
    
    }
    // 上述接口的一個實現(xiàn)

    package x.y.service;
    
    public class DefaultFooService implements FooService {
    
      public Foo getFoo(String fooName) {
        throw new UnsupportedOperationException();
      }
    
      public Foo getFoo(String fooName, String barName) {
        throw new UnsupportedOperationException();
      }
    
      public void insertFoo(Foo foo) {
        throw new UnsupportedOperationException();
      }
    
      public void updateFoo(Foo foo) {
        throw new UnsupportedOperationException();
      }
    
    }

我們假定,F(xiàn)ooService的前兩個方法(getFoo(String) 和getFoo(String, String))必須執(zhí)行在只讀事務(wù)上下文中,其他的方法(insertFoo(Foo)和 updateFoo(Foo))必須執(zhí)行在可讀寫事務(wù)上下文中。定義配置文件如下:

   
   
   
  
  
  

  
  
  
  
    
    
    
    
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  

  
  
  
   
  
  
  

分析一下上面的配置。我們要把一個服務(wù)對象("fooService" bean)做成事務(wù)性的。 施加的事務(wù)語義封裝在定義中。 “把所有以 "get" 開頭的方法看做執(zhí)行在只讀事務(wù)上下文中, 其余的方法執(zhí)行在默認語義的事務(wù)上下文中”。 其中的 "transaction-manager" 屬性被設(shè)置為一個指向 PlatformTransactionManager bean的名字(這里指 "txManager"),該bean將會真正管理事務(wù)。

配置中最后一段是 的定義, 它確保由 "txAdvice" bean定義的事務(wù)通知在應(yīng)用中合適的點被執(zhí)行。 首先我們定義了 一個切面,它匹配 FooService 接口定義的所有操作, 我們把該切面叫做 "fooServiceOperation"。然后我們用一個通知器(advisor)把這個切面與 "txAdvice" 綁定在一起, 表示當 "fooServiceOperation" 執(zhí)行時,"txAdvice" 定義的通知邏輯將被執(zhí)行。
元素定義是AspectJ的切面表示法.

上面的配置將為"fooService" bean創(chuàng)建一個代理對象,這個代理對象被裝配了事務(wù)通知,所以當它的相應(yīng)方法被調(diào)用時,一個事務(wù)將被啟動、掛起、被標記為只讀,或者其它(根據(jù)該方法所配置的事務(wù)語義)。

spring回滾

在Spring框架的事務(wù)架構(gòu)里,當context的事務(wù)里的代碼拋出 Exception 時事務(wù)進行回滾。Spring框架的事務(wù)基礎(chǔ)架構(gòu)代碼將從調(diào)用的堆棧里捕獲到任何未處理的 Exception,并將標識事務(wù)將回滾。然而,請注意Spring框架的事務(wù)基礎(chǔ)架構(gòu)代碼將默認地只在拋出運行時和unchecked exceptions時才標識事務(wù)回滾。也就是說,當拋出一個 RuntimeException 或其子類例的實例時。(Errors 也一樣 - 默認地 - 標識事務(wù)回滾。)從事務(wù)方法中拋出的Checked exceptions將不被標識進行事務(wù)回滾。

下面的XML配置片斷里示范了如何配置一個用于回滾的checked、應(yīng)用程序特定的 Exception 類型。


  
  
  
  

有時候你不想在異常拋出的時候回滾事務(wù),就可以使用“不回滾規(guī)則”。 在下面的例子中,我們告訴Spring 框架即使遇到?jīng)]有經(jīng)過處理的InstrumentNotFoundException異常,也不要回滾事務(wù)。


  
  
  
  

當Spring框架捕獲到一個異常后會檢查配置回滾規(guī)則來決定是不是要回滾事務(wù),這時候會遵循最匹配的規(guī)則。 所以在下面這種配置中,除了InstrumentNotFoundException這種類型的異常不會導(dǎo)致事務(wù)回滾以外,其他任何類型的異常都會。


  
  
  

第二種方法是通過 編程式 方式來指定回滾事務(wù)。 雖然寫法非常的簡單,但是這個方法是高侵入性的,并且使你的代碼與Spring框架的事務(wù)架構(gòu)高度耦合。 下面的代碼片斷里示范了Spring框架管理事務(wù)的編程式回滾:

public void resolvePosition() {
  try {
    // some business logic...
  } catch (NoProductInStockException ex) {
    // trigger rollback programmatically
    TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
  }
}

編程式方法的回滾對你來說是可見,如果你需要它你就可以使用,但是使用它就直接違反了在你的應(yīng)用中使用一個純基于POJO的模型。

@Transactional注解

除了基于XML文件的聲明式事務(wù)配置外,你也可以采用基于注解式的事務(wù)配置方法。直接在Java源代碼中聲明事務(wù)語義的做法讓事務(wù)聲明和將受其影響的代碼距離更近了,而且一般來說不會有不恰當?shù)鸟詈系娘L(fēng)險,因為,使用事務(wù)性的代碼幾乎總是被部署在事務(wù)環(huán)境中舉例如下:

    @Transactional
    public class DefaultFooService implements FooService {
    
      Foo getFoo(String fooName);
    
      Foo getFoo(String fooName, String barName);
    
      void insertFoo(Foo foo);
    
      void updateFoo(Foo foo);
    }

當上述的POJO定義在Spring IoC容器里時,上述bean實例僅僅通過一 行xml配置就可以使它具有事務(wù)性的。如下:

    
    
    
      
      
      
    
      
      
    
      
      
      
         
      
      
      
    
    
    

@Transactional 注解可以被應(yīng)用于接口定義和接口方法、類定義和類的 public 方法上。 然而,請注意只是使用 @Transactional 注解并不會啟用事務(wù)行為, 它僅僅 是一種元數(shù)據(jù),能夠被可以識別 @Transactional 注解和上述的配置適當?shù)木哂惺聞?wù)行為的beans所使用。上面的例子中,其實正是 元素的出現(xiàn) 開啟 了事務(wù)行為。

Spring團隊的建議是你只在具體的類上使用 @Transactional 注解, 而不要注解在接口上。你當然可以在接口(或接口方法)上使用 @Transactional 注解, 但是這只有在你使用基于接口的代理時它才會生效。因為注解是 不能繼承 的, 這就意味著如果你正在使用基于類的代理時,事務(wù)的設(shè)置將不能被基于類的代理所識別,而且對象也不會被事務(wù)代理所包裝 (這是很糟糕的)。

元素上的"proxy-target-class" 屬性 控制了有什么類型的事務(wù)性代理會為使用@Transactional 來注解的類創(chuàng)建代理。 如果"proxy-target-class" 屬性被設(shè)為"true",那么基于類的代理就會被創(chuàng)建。 如果"proxy-target-class" 屬性被設(shè)為"false" 或者沒設(shè),那么會創(chuàng)建基于接口的標準JDK代理。

在多數(shù)情形下,方法的事務(wù)設(shè)置將被優(yōu)先執(zhí)行。在下列情況下,例如: DefaultFooService 類在類的級別上被注解為只讀事務(wù),但是,這個類中的 updateFoo(Foo) 方法的 @Transactional 注解的事務(wù)設(shè)置將優(yōu)先于類級別注解的事務(wù)設(shè)置。

@Transactional(readOnly = true)
public class DefaultFooService implements FooService {

  public Foo getFoo(String fooName) {
    // do something
  }

    // these settings have precedence for this method
    @Transactional(readOnly = false, propagation = Propagation.REQUIRES_NEW)
    public void updateFoo(Foo foo) {
        // do something
        
    }
}

    

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/70257.html

相關(guān)文章

  • 15個經(jīng)典的Spring面試常見問題

    摘要:我自己總結(jié)的學(xué)習(xí)的系統(tǒng)知識點以及面試問題,已經(jīng)開源,目前已經(jīng)。目前最新的版本中模塊的組件已經(jīng)被廢棄掉,同時增加了用于異步響應(yīng)式處理的組件。每一次請求都會產(chǎn)生一個新的,該僅在當前內(nèi)有效。顯而易見,這種模式存在很多問題。 我自己總結(jié)的Java學(xué)習(xí)的系統(tǒng)知識點以及面試問題,已經(jīng)開源,目前已經(jīng) 41k+ Star。會一直完善下去,歡迎建議和指導(dǎo),同時也歡迎Star: https://githu...

    sarva 評論0 收藏0
  • Spring Boot 參考指南(使用JTA分布式事務(wù)

    摘要:使用事務(wù)管理器是支持的一個流行的開源事務(wù)管理器實現(xiàn),你可以使用啟動器向項目添加適當?shù)囊蕾図棧c和一樣,將自動配置并對進行后處理,以確保啟動和關(guān)閉順序是正確的。 37. 用JTA分布式事務(wù) 通過使用Atomikos或Bitronix嵌入式事務(wù)管理器,Spring Boot支持跨多個XA資源的分布式JTA事務(wù),在部署到合適的Java EE應(yīng)用服務(wù)器時也支持JTA事務(wù)。 當檢測到JTA環(huán)境時...

    silenceboy 評論0 收藏0
  • 面試分享:最全Spring事務(wù)面試考點整理

    摘要:和事務(wù)的關(guān)系關(guān)系型數(shù)據(jù)庫某些消息隊列等產(chǎn)品或中間件稱為事務(wù)性資源,因為它們本身支持事務(wù),也能夠處理事務(wù)。事務(wù)的傳播特性,,,,,,強制要求要有一個物理事務(wù)。外圍事務(wù)不會被內(nèi)部事務(wù)的回滾狀態(tài)影響。不支持當前事務(wù)。 Spring和事務(wù)的關(guān)系 關(guān)系型數(shù)據(jù)庫、某些消息隊列等產(chǎn)品或中間件稱為事務(wù)性資源,因為它們本身支持事務(wù),也能夠處理事務(wù)。 Spring很顯然不是事務(wù)性資源,但是它可...

    graf 評論0 收藏0
  • 基于Spring中的事務(wù)管理機制

    摘要:中的事務(wù)管理分類編程式事務(wù)管理機制聲明式事務(wù)管理機制下面就銀行轉(zhuǎn)賬這一實例來講解如何利用這兩種由提供的事務(wù)處理機制來進行相應(yīng)的事務(wù)處理。 什么是事務(wù)? 通俗理解,事務(wù)其實就是一系列指令的集合。 為什么要使用事務(wù)管理? 我們在實際業(yè)務(wù)場景中,經(jīng)常會遇到數(shù)據(jù)頻繁修改讀取的問題。在同一時刻,不同的業(yè)務(wù)邏輯對同一個表數(shù)據(jù)進行修改,這種沖突很可能造成數(shù)據(jù)不可挽回的錯亂,所以我們需要用事務(wù)來對數(shù)據(jù)...

    SnaiLiu 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<