久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

spring事務(wù)隔離級別、傳播行為以及spring+mybatis+atomikos實現(xiàn)分布式事務(wù)管理的方法

146次閱讀
沒有評論

共計 5589 個字符,預(yù)計需要花費 14 分鐘才能閱讀完成。

行業(yè)資訊    
數(shù)據(jù)庫    
MySQL 數(shù)據(jù)庫    
spring 事務(wù)隔離級別、傳播行為以及 spring+mybatis+atomikos 實現(xiàn)分布式事務(wù)管理的方法

自動寫代碼機器人,免費開通

丸趣 TV 小編給大家分享一下 spring 事務(wù)隔離級別、傳播行為以及 spring+mybatis+atomikos 實現(xiàn)分布式事務(wù)管理的方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

1. 事務(wù)的定義:事務(wù)是指多個操作單元組成的合集,多個單元操作是整體不可分割的,要么都操作不成功,要么都成功。其必須遵循四個原則(ACID)。

原子性(Atomicity):即事務(wù)是不可分割的最小工作單元,事務(wù)內(nèi)的操作要么全做,要么全不做;

一致性(Consistency):在事務(wù)執(zhí)行前數(shù)據(jù)庫的數(shù)據(jù)處于正確的狀態(tài),而事務(wù)執(zhí)行完成后數(shù)據(jù)庫的數(shù)據(jù)還是應(yīng)該處于正確的狀態(tài),即數(shù)據(jù)完整性約束沒有被破壞;如銀行轉(zhuǎn)帳,A 轉(zhuǎn)帳給 B,必須保證 A 的錢一定轉(zhuǎn)給 B,一定不會出現(xiàn) A 的錢轉(zhuǎn)了但 B 沒收到,否則數(shù)據(jù)庫的數(shù)據(jù)就處于不一致(不正確)的狀態(tài)。

隔離性(Isolation):并發(fā)事務(wù)執(zhí)行之間互不影響,在一個事務(wù)內(nèi)部的操作對其他事務(wù)是不產(chǎn)生影響,這需要事務(wù)隔離級別來指定隔離性;

持久性(Durability):事務(wù)一旦執(zhí)行成功,它對數(shù)據(jù)庫的數(shù)據(jù)的改變必須是永久的,不會因比如遇到系統(tǒng)故障或斷電造成數(shù)據(jù)不一致或丟失。

2. 事務(wù)的類型

數(shù)據(jù)庫分為本地事務(wù)跟全局事務(wù)

本地事務(wù):普通事務(wù),獨立一個數(shù)據(jù)庫,能保證在該數(shù)據(jù)庫上操作的 ACID。

分布式事務(wù):涉及兩個或多個數(shù)據(jù)庫源的事務(wù),即跨越多臺同類或異類數(shù)據(jù)庫的事務(wù)(由每臺數(shù)據(jù)庫的本地事務(wù)組成的),分布式事務(wù)旨在保證這些本地事務(wù)的所有操作的 ACID,使事務(wù)可以跨越多臺數(shù)據(jù)庫;

Java 事務(wù)類型分為 JDBC 事務(wù)跟 JTA 事務(wù)

JDBC 事務(wù):即為上面說的數(shù)據(jù)庫事務(wù)中的本地事務(wù),通過 connection 對象控制管理。

JTA 事務(wù):JTA 指 Java 事務(wù) API(Java Transaction API),是 Java EE 數(shù)據(jù)庫事務(wù)規(guī)范,JTA 只提供了事務(wù)管理接口,由應(yīng)用程序服務(wù)器廠商(如 WebSphere Application Server)提供實現(xiàn),JTA 事務(wù)比 JDBC 更強大,支持分布式事務(wù)。

按是否通過編程分為聲明式事務(wù)和編程式事務(wù),參考 http://blog.csdn.net/liaohaojian/article/details/70139151

聲明式事務(wù):通過 XML 配置或者注解實現(xiàn)。

編程式事務(wù):通過編程代碼在業(yè)務(wù)邏輯時需要時自行實現(xiàn),粒度更小。

3.Spring 事務(wù)隔離級別:spring 有五大隔離級別,其在 TransactionDefinition 接口中定義。看源碼可知,其默 isolation_default(底層數(shù)據(jù)庫默認級別),其他四個隔離級別跟數(shù)據(jù)庫隔離級別一致。

ISOLATION_DEFAULT:用底層數(shù)據(jù)庫的默認隔離級別,數(shù)據(jù)庫管理員設(shè)置什么就是什么

ISOLATION_READ_UNCOMMITTED(未提交讀):最低隔離級別、事務(wù)未提交前,就可被其他事務(wù)讀取(會出現(xiàn)幻讀、臟讀、不可重復讀)

ISOLATION_READ_COMMITTED(提交讀):一個事務(wù)提交后才能被其他事務(wù)讀取到(該隔離級別禁止其他事務(wù)讀取到未提交事務(wù)的數(shù)據(jù)、所以還是會造成幻讀、不可重復讀)、sql server 默認級別

ISOLATION_REPEATABLE_READ(可重復讀):可重復讀,保證多次讀取同一個數(shù)據(jù)時,其值都和事務(wù)開始時候的內(nèi)容是一致,禁止讀取到別的事務(wù)未提交的數(shù)據(jù)(該隔離基本可防止臟讀,不可重復讀(重點在修改),但會出現(xiàn)幻讀(重點在增加與刪除))(MySql 默認級別,更改可通過 set transaction isolation level 級別)

ISOLATION_SERIALIZABLE(序列化):代價最高最可靠的隔離級別(該隔離級別能防止臟讀、不可重復讀、幻讀)

丟失更新:兩個事務(wù)同時更新一行數(shù)據(jù),最后一個事務(wù)的更新會覆蓋掉第一個事務(wù)的更新,從而導致第一個事務(wù)更新的數(shù)據(jù)丟失,這是由于沒有加鎖造成的;

幻讀:同樣的事務(wù)操作過程中,不同時間段多次(不同事務(wù))讀取同一數(shù)據(jù),讀取到的內(nèi)容不一致(一般是行數(shù)變多或變少)。

臟讀:一個事務(wù)讀取到另外一個未提及事務(wù)的內(nèi)容,即為臟讀。

不可重復讀:同一事務(wù)中,多次讀取內(nèi)容不一致(一般行數(shù)不變,而內(nèi)容變了)。

幻讀與不可重復讀的區(qū)別:幻讀的重點在于插入與刪除,即第二次查詢會發(fā)現(xiàn)比第一次查詢數(shù)據(jù)變少或者變多了,以至于給人一種幻象一樣,而不可重復讀重點在于修改,即第二次查詢會發(fā)現(xiàn)查詢結(jié)果比第一次查詢結(jié)果不一致,即第一次結(jié)果已經(jīng)不可重現(xiàn)了。

數(shù)據(jù)庫隔離級別越高,執(zhí)行代價越高,并發(fā)執(zhí)行能力越差,因此在實際項目開發(fā)使用時要綜合考慮,為了考慮并發(fā)性能一般使用提交讀隔離級別,它能避免丟失更新和臟讀,盡管不可重復讀和幻讀不能避免,但可以在可能出現(xiàn)的場合使用悲觀鎖或樂觀鎖來解決這些問題。

4. 傳播行為:有七大傳播行為,也是在 TransactionDefinition 接口中定義。

PROPAGATION_REQUIRED:支持當前事務(wù),如當前沒有事務(wù),則新建一個。

PROPAGATION_SUPPORTS:支持當前事務(wù),如當前沒有事務(wù),則已非事務(wù)性執(zhí)行(源碼中提示有個注意點,看不太明白,留待后面考究)。

PROPAGATION_MANDATORY:支持當前事務(wù),如當前沒有事務(wù),則拋出異常(強制一定要在一個已經(jīng)存在的事務(wù)中執(zhí)行,業(yè)務(wù)方法不可獨自發(fā)起自己的事務(wù))。

PROPAGATION_REQUIRES_NEW:始終新建一個事務(wù),如當前原來有事務(wù),則把原事務(wù)掛起。

PROPAGATION_NOT_SUPPORTED:不支持當前事務(wù),始終已非事務(wù)性方式執(zhí)行,如當前事務(wù)存在,掛起該事務(wù)。

PROPAGATION_NEVER:不支持當前事務(wù);如果當前事務(wù)存在,則引發(fā)異常。

PROPAGATION_NESTED:如果當前事務(wù)存在,則在嵌套事務(wù)中執(zhí)行,如果當前沒有事務(wù),則執(zhí)行與 PROPAGATION_REQUIRED 類似的操作(注意:當應(yīng)用到 JDBC 時,只適用 JDBC 3.0 以上驅(qū)動)。

5.Spring 事務(wù)支持

1.spring 提供了很多內(nèi)置事務(wù)管理器,支持不同數(shù)據(jù)源。常見的有三大類

DataSourceTransactionManager:org.springframework.jdbc.datasource 包下,數(shù)據(jù)源事務(wù)管理類,提供對單個 javax.sql.DataSource 數(shù)據(jù)源的事務(wù)管理,只要用于 JDBC,Mybatis 框架事務(wù)管理。

HibernateTransactionManager:org.springframework.orm.hibernate3 包下,數(shù)據(jù)源事務(wù)管理類,提供對單個 org.hibernate.SessionFactory 事務(wù)支持,用于集成 Hibernate 框架時的事務(wù)管理;注意:該事務(wù)管理器只支持 Hibernate3+ 版本,且 Spring3.0+ 版本只支持 Hibernate 3.2+ 版本;

JtaTransactionManager:位于 org.springframework.transaction.jta 包中,提供對分布式事務(wù)管理的支持,并將事務(wù)管理委托給 Java EE 應(yīng)用服務(wù)器,或者自定義一個本地 JTA 事務(wù)管理器,嵌套到應(yīng)用程序中。

內(nèi)置事務(wù)管理器都繼承了抽象類 AbstractPlatformTransactionManager,而 AbstractPlatformTransactionManager 又繼承了接口 PlatformTransactionManager

Spring 框架支持事務(wù)管理的核心是事務(wù)管理器抽象,對于不同的數(shù)據(jù)訪問框架通過實現(xiàn)策略接口 PlatformTransactionManager,從而能支持多鐘數(shù)據(jù)訪問框架的事務(wù)管理。

PlatformTransactionManager 接口定義如下

TransactionStatus 接口定義如下:

public interface TransactionStatus extends SavepointManager {boolean isNewTransaction(); // 返回當前事務(wù)是否是新的事務(wù)
 boolean hasSavepoint(); // 返回當前事務(wù)是否有保存點
 void setRollbackOnly(); // 設(shè)置事務(wù)回滾
 boolean isRollbackOnly(); // 設(shè)置當前事務(wù)是否應(yīng)該回滾
 void flush(); // 用于刷新底層會話中的修改到數(shù)據(jù)庫,一般用于刷新如 Hibernate/JPA 的會話,可能對如 JDBC 類型的事務(wù)無任何影響;boolean isCompleted(); // 返回事務(wù)是否完成}

2.Spring 分布式事務(wù)配置

引用應(yīng)用服務(wù)器(如 Tomcat)的 JNDI 數(shù)據(jù)源,間接實現(xiàn) JTA 事務(wù)管理,依賴于應(yīng)用服務(wù)器

直接集成 JOTM(官網(wǎng):http://jotm.objectweb.org/)、Atomikos(官網(wǎng):https://www.atomikos.com/)提供 JTA 事務(wù)管理(無應(yīng)用服務(wù)器支持,常用于單元測試)

使用特定于應(yīng)用服務(wù)器的事務(wù)管理器,使用 JTA 事務(wù)的高級功能(Weblogic,Websphere)

1). 引用應(yīng)用服務(wù)器(如 Tomcat)的 JNDI 數(shù)據(jù)源,間接實現(xiàn) JTA 事務(wù)管理,配置如下

 beans xmlns= http://www.springframework.org/schema/beans
xmlns:xsi= http://www.w3.org/2001/XMLSchema-instance
xmlns:jee= http://www.springframework.org/schema/jee
xsi:schemaLocation=
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/jee
http://www.springframework.org/schema/jee/spring-jee-3.0.xsd
!-- JNDI 數(shù)據(jù)源 --
jee:jndi-lookup id= dataSource jndi-name= jdbc/test /
!-- JTA 事務(wù)管理器 --
bean id= txManager >

2)使用 Atomikos 實現(xiàn)分布式事務(wù)管理,配置如下:

 ?xml version= 1.0 encoding= UTF-8 ?
beans xmlns= http://www.springframework.org/schema/beans
xmlns:xsi= http://www.w3.org/2001/XMLSchema-instance
xmlns:p= http://www.springframework.org/schema/p
xmlns:aop= http://www.springframework.org/schema/aop
xmlns:tx= http://www.springframework.org/schema/tx
xmlns:context= http://www.springframework.org/schema/context
xmlns:task= http://www.springframework.org/schema/task
xsi:schemaLocation= http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
http://www.springframework.org/schema/task
http://www.springframework.org/schema/task/spring-task-3.0.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
context:component-scan base-package= com.suicai.*.service.impl /
context:component-scan base-package= com.suicai.util /
!-- 此方法加載的配置文件僅僅在 xml 中使用, 但是工具類都采用注解的方式 --
bean >

看完了這篇文章,相信你對 spring 事務(wù)隔離級別、傳播行為以及 spring+mybatis+atomikos 實現(xiàn)分布式事務(wù)管理的方法有了一定的了解,想了解更多相關(guān)知識,歡迎關(guān)注丸趣 TV 行業(yè)資訊頻道,感謝各位的閱讀!

向 AI 問一下細節(jié)

丸趣 TV 網(wǎng) - 提供最優(yōu)質(zhì)的資源集合!

正文完
 
丸趣
版權(quán)聲明:本站原創(chuàng)文章,由 丸趣 2023-12-18發(fā)表,共計5589字。
轉(zhuǎn)載說明:除特殊說明外本站除技術(shù)相關(guān)以外文章皆由網(wǎng)絡(luò)搜集發(fā)布,轉(zhuǎn)載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 扎兰屯市| 承德市| 吕梁市| 托里县| 左贡县| 石城县| 麻阳| 济宁市| 福州市| 偃师市| 天水市| 安塞县| 辽阳市| 永清县| 辛集市| 景宁| 天水市| 临高县| 铜陵市| 瓦房店市| 龙胜| 天台县| 贡觉县| 苏尼特右旗| 中山市| 晋江市| 綦江县| 延吉市| 平乐县| 白朗县| 庆安县| 东至县| 黔西县| 喀喇沁旗| 松滋市| 永顺县| 昌吉市| 科技| 河北省| 滦平县| 宜宾县|