事務,是描述一組操作的抽象,比如對資料庫的一組操作,要麼全部成功,要麼全部失敗。事務具有4個特性:atomicity(原子性),consistency(一致性),isolation(隔離性),durability(永續性)。在實際開發中,我們對事務應用最多就是在資料庫操作這一環,特別是spring對資料庫事務進行了封裝管理。spring對事務的支援,確實很強大,但是從本質上來講:事務是否生效取決資料庫底層是否支援(比如mysql的myisam引擎就不支援事務,spring能奈何!),同時乙個事務的多個操作需要在同乙個connection上。事務也往往是在業務邏輯層來控制。本篇部落格將通過手寫乙個demo來分析spring事務底層到底是如何幫助我們輕鬆完成事務管理的!
先來看一眼工程結構:
在spring中,有時候我們是不是要配置多個資料來源datasource?很顯然,spring需要通過datasource來得到運算元據庫的管道connection,這有點類似於jndi查詢。
這裡通過connectionholder類來完成這個過程,需要思考的是在多執行緒下,這顯然是存在問題的。為避免多執行緒問題,難道我們採用執行緒安全的map,比如concurrenthashmap,其實我們真正的目的是什麼?是保證乙個執行緒下,乙個事務的多個操作拿到的是乙個connection,顯然使用concurrenthashmap根本無法保證!
spring很聰明,她提供了一種思路,來解決,看下面的**!
本來執行緒不安全的,通過threadlocal這麼封裝一下,立刻就變成了執行緒的區域性變數,不僅僅安全了,還保證了乙個執行緒下面的操作拿到的connection是同乙個物件!這種思想,確實非常巧妙,這也是無鎖程式設計思想的一種方式!
transactionmanager,這個我們經常在spring裡面進行配置吧,事務大管家!
這裡通過這2個dao,想模擬乙個事務中賬戶購買、下單2個操作。
到這裡,可以清晰的看到spring事務管理的乙個縮影了吧!
這裡,主要是模擬spring的注入以及多使用者併發請求。
執行結果
你可以發現,乙個執行緒中的乙個事務的多個操作,使用的是同乙個connection
好了,到這裡,你是否能對spring實現事務的思想有所了解呢?
透徹理解Spring事務設計思想之手寫實現
事務,是描述一組操作的抽象,比如對資料庫的一組操作,要麼全部成功,要麼全部失敗。事務具有4個特性 atomicity 原子性 consistency 一致性 isolation 隔離性 durability 永續性 在實際開發中,我們對事務應用最多就是在資料庫操作這一環,特別是spring對資料庫事...
透徹理解Spring事務設計思想之手寫實現
事務,是描述一組操作的抽象,比如對資料庫的一組操作,要麼全部成功,要麼全部失敗。事務具有4個特性 atomicity 原子性 consistency 一致性 isolation 隔離性 durability 永續性 在實際開發中,我們對事務應用最多就是在資料庫操作這一環,特別是spring對資料庫事...
spring事務理解
由於以前都是對整個selevlet或者jsp進行事務,所以昨天自然的也以為可在controller類中進行事務 在handlerequest方法中使用了 code jzlogic.updatea a jzlogic.inserb b code jzlogic已經設定事務規則,對insert upda...