事務(wù)
在軟件開發(fā)領(lǐng)域,全有或全無的操作被稱為事物(transaction)。事務(wù)允許你將幾個(gè)操作組合成一個(gè)要么全部發(fā)生要么全部不發(fā)生的工作單元。
事務(wù)的特性
- 原子性(Atomic)
事務(wù)是由一個(gè)或多個(gè)活動(dòng)所組成的一個(gè)工作單元。原子性確保事務(wù)中的工作要么全部發(fā)生要么全部不發(fā)生。如果所有的活動(dòng)都成功了,那么事務(wù)也就成功了,如果有任意一個(gè)活動(dòng)失敗,那么整個(gè)事務(wù)也就失敗并且進(jìn)行回滾。
- 一致性(Consistent)
一旦事務(wù)完成(不管成功還是失敗),系統(tǒng)必須確保他所建模的業(yè)務(wù)處于一致的狀態(tài)?,F(xiàn)實(shí)的數(shù)據(jù)不應(yīng)該被損壞。
- 隔離性(Isolated)
事務(wù)允許多個(gè)用戶對相同的數(shù)據(jù)進(jìn)行操作,每個(gè)用戶的操作不會(huì)與其他用戶糾纏在一起。因此,事務(wù)應(yīng)該彼此隔離,避免發(fā)生同步讀寫相同數(shù)據(jù)的事情(注意的是,隔離性往往涉及到鎖定數(shù)據(jù)庫中的行或者表)。
- 持久性(Durable)
一旦事務(wù)完成,事務(wù)的結(jié)果應(yīng)該持久化,這樣就能從任何系統(tǒng)的系統(tǒng)奔潰中回復(fù)過來。這一般會(huì)涉及將結(jié)果存儲(chǔ)到數(shù)據(jù)庫或者其他形式的持久化存儲(chǔ)中。
Spring對事務(wù)的支持
- 編碼式事務(wù)
編碼式事務(wù)允許用戶在代碼中精確定義事務(wù)的邊界 - 聲明式事務(wù)
聲明式事務(wù)(基于AOP)有助于用戶將操作與事務(wù)規(guī)則進(jìn)行解耦。
選擇編碼式事務(wù)還是聲明式事務(wù)很大程度上是在細(xì)粒度和易用性之間進(jìn)行權(quán)衡。當(dāng)你使用編碼式事務(wù),你能夠精確的控制事務(wù)的邊界,他們的開始于結(jié)束取決于你的需求。
事務(wù)管理器
Spring并不直接管理事務(wù),而是提供了多種事務(wù)管理器,他們將事務(wù)管理的職責(zé)委托給 JTA 或其他持久化機(jī)制所提供的平臺(tái)相關(guān)事務(wù)實(shí)現(xiàn)。每個(gè)事務(wù)管理器充當(dāng)某一個(gè)特定平臺(tái)的事務(wù)實(shí)現(xiàn)的門面。這是的Spring在使用事務(wù)時(shí),幾乎不用關(guān)注實(shí)際的事務(wù)實(shí)現(xiàn)時(shí)什么。
