javascript
【手写系列】透彻理解Spring事务设计思想之手写实现
事務,是描述一組操作的抽象,比如對數據庫的一組操作,要么全部成功,要么全部失敗。事務具有4個特性:Atomicity(原子性),Consistency(一致性),Isolation(隔離性),Durability(持久性)。在實際開發中,我們對事務應用最多就是在數據庫操作這一環,特別是Spring對數據庫事務進行了封裝管理。Spring對事務的支持,確實很強大,但是從本質上來講:事務是否生效取決數據庫底層是否支持(比如MySQL的MyISAM引擎就不支持事務,Spring能奈何!),同時一個事務的多個操作需要在同一個Connection上。事務也往往是在業務邏輯層來控制。本篇博客將通過手寫一個Demo來分析Spring事務底層到底是如何幫助我們輕松完成事務管理的!
透徹理解Spring事務設計思想之手寫實現
先來看一眼工程結構:
工程結構?
ConnectionHolder
ConnectionHolder?
在Spring中,有時候我們是不是要配置多個數據源DataSource?很顯然,Spring需要通過DataSource來得到操作數據庫的管道Connection,這有點類似于JNDI查找。
這里通過ConnectionHolder類來完成這個過程,需要思考的是在多線程下,這顯然是存在問題的。為避免多線程問題,難道我們采用線程安全的Map,比如ConcurrentHashMap,其實我們真正的目的是什么?是保證一個線程下,一個事務的多個操作拿到的是一個Connection,顯然使用ConcurrentHashMap根本無法保證!
Spring很聰明,她提供了一種思路,來解決,看下面的代碼!
?
SingleThreadConnectionHolder
SingleThreadConnectionHolder?
本來線程不安全的,通過ThreadLocal這么封裝一下,立刻就變成了線程的局部變量,不僅僅安全了,還保證了一個線程下面的操作拿到的Connection是同一個對象!這種思想,確實非常巧妙,這也是無鎖編程思想的一種方式!
TransactionManager
TransactionManager?
TransactionManager,這個我們經常在Spring里面進行配置吧,事務大管家!
UserAccountDao、UserOrderDao
UserAccountDao UserOrderDao?
這里通過這2個DAO,想模擬一個事務中賬戶購買、下單2個操作。
UserService
UserService?
到這里,可以清晰的看到Spring事務管理的一個縮影了吧!
Test
測試?
這里,主要是模擬Spring的注入以及多用戶并發請求。
?
運行結果
運行結果?
你可以發現,一個線程中的一個事務的多個操作,使用的是同一個Connection!
好了,到這里,你是否能對Spring實現事務的思想有所了解呢?
?
手寫系列相關爆文
【手寫系列】寫出我的第一個框架:迷你版Spring MVC
【手寫系列】透徹理解MyBatis設計思想之手寫實現
【手寫系列】純手寫實現一個高可用的RPC
【手寫系列】理解數據庫連接池底層原理之手寫實現
【手寫系列】對HashMap的思考及手寫實現
【手寫系列】純手寫實現JDK動態代理
【手寫系列】寫一個迷你版的Tomcat
?
作者:張豐哲
鏈接:https://www.jianshu.com/p/1becdc376f5d
總結
以上是生活随笔為你收集整理的【手写系列】透彻理解Spring事务设计思想之手写实现的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 程序员吐槽:放弃公务员进阿里,如今担心中
- 下一篇: 好文 | 架构师更多的是和人打交道,说说