1. 程式人生 > 其它 >面試官:說說 Spring 事務設計原理?面試必問!

面試官:說說 Spring 事務設計原理?面試必問!

作者:張豐哲
來源:www.jianshu.com/p/1becdc376f5d

前言

事務,是描述一組操作的抽象,比如對資料庫的一組操作,要麼全部成功,要麼全部失敗。事務具有4個特性:Atomicity(原子性),Consistency(一致性),Isolation(隔離性),Durability(永續性)。

在實際開發中,我們對事務應用最多就是在資料庫操作這一環,特別是Spring對資料庫事務進行了封裝管理。

Spring對事務的支援,確實很強大,但是從本質上來講:事務是否生效取決資料庫底層是否支援(比如MySQL的MyISAM引擎就不支援事務,Spring能奈何!),同時一個事務的多個操作需要在同一個Connection上。事務也往往是在業務邏輯層來控制。

本篇部落格將通過手寫一個Demo來分析Spring事務底層到底是如何幫助我們輕鬆完成事務管理的!

透徹理解Spring事務設計思想之手寫實現

推薦一個 Spring Boot 基礎教程及實戰示例:
https://www.javastack.cn/categories/Spring-Boot/

先來看一眼工程結構:

ConnectionHolder

在Spring中,有時候我們是不是要配置多個數據源DataSource?很顯然,Spring需要通過DataSource來得到操作資料庫的管道Connection,這有點類似於JNDI查詢。

這裡通過ConnectionHolder類來完成這個過程,需要思考的是在多執行緒下,這顯然是存在問題的。為避免多執行緒問題,難道我們採用執行緒安全的Map,比如ConcurrentHashMap,其實我們真正的目的是什麼?是保證一個執行緒下,一個事務的多個操作拿到的是一個Connection,顯然使用ConcurrentHashMap根本無法保證!

Spring很聰明,她提供了一種思路,來解決,看下面的程式碼!

SingleThreadConnectionHolder

本來執行緒不安全的,通過ThreadLocal這麼封裝一下,立刻就變成了執行緒的區域性變數,不僅僅安全了,還保證了一個執行緒下面的操作拿到的Connection是同一個物件!這種思想,確實非常巧妙,這也是無鎖程式設計思想的一種方式!

TransactionManager

TransactionManager,這個我們經常在Spring裡面進行配置吧,事務大管家!另外,Spring 系列面試題和答案全部整理好了,微信搜尋​Java技術棧,在後臺傳送:面試,​可以線上閱讀。

UserAccountDao、UserOrderDao

這裡通過這2個DAO,想模擬一個事務中賬戶購買、下單2個操作。

UserService

到這裡,可以清晰的看到Spring事務管理的一個縮影了吧!

Test

這裡,主要是模擬Spring的注入以及多使用者併發請求。

執行結果

你可以發現,一個執行緒中的一個事務的多個操作,使用的是同一個Connection!

好了,到這裡,你是否能對Spring實現事務的思想有所瞭解呢?

近期熱文推薦:

1.1,000+ 道 Java面試題及答案整理(2021最新版)

2.別在再滿屏的 if/ else 了,試試策略模式,真香!!

3.臥槽!Java 中的 xx ≠ null 是什麼新語法?

4.Spring Boot 2.5 重磅釋出,黑暗模式太炸了!

5.《Java開發手冊(嵩山版)》最新發布,速速下載!

覺得不錯,別忘了隨手點贊+轉發哦!