事務(wù)
在軟件開(kāi)發(fā)領(lǐng)域凭疮,全有或全無(wú)的操作被稱(chē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)∏渌現(xiàn)實(shí)的數(shù)據(jù)不應(yīng)該被損壞堕花。
- 隔離性(Isolated)
事務(wù)允許多個(gè)用戶(hù)對(duì)相同的數(shù)據(jù)進(jìn)行操作粥鞋,每個(gè)用戶(hù)的操作不會(huì)與其他用戶(hù)糾纏在一起。因此壕曼,事務(wù)應(yīng)該彼此隔離等浊,避免發(fā)生同步讀寫(xiě)相同數(shù)據(jù)的事情(注意的是,隔離性往往涉及到鎖定數(shù)據(jù)庫(kù)中的行或者表)筹燕。
- 持久性(Durable)
一旦事務(wù)完成,事務(wù)的結(jié)果應(yīng)該持久化撒踪,這樣就能從任何系統(tǒng)的系統(tǒng)奔潰中回復(fù)過(guò)來(lái)。這一般會(huì)涉及將結(jié)果存儲(chǔ)到數(shù)據(jù)庫(kù)或者其他形式的持久化存儲(chǔ)中援奢。
Spring對(duì)事務(wù)的支持
- 編碼式事務(wù)
編碼式事務(wù)允許用戶(hù)在代碼中精確定義事務(wù)的邊界 - 聲明式事務(wù)
聲明式事務(wù)(基于AOP)有助于用戶(hù)將操作與事務(wù)規(guī)則進(jìn)行解耦忍捡。
選擇編碼式事務(wù)還是聲明式事務(wù)很大程度上是在細(xì)粒度和易用性之間進(jìn)行權(quán)衡。當(dāng)你使用編碼式事務(wù)具篇,你能夠精確的控制事務(wù)的邊界凌埂,他們的開(kāi)始于結(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)的門(mén)面胳蛮。這是的Spring在使用事務(wù)時(shí),幾乎不用關(guān)注實(shí)際的事務(wù)實(shí)現(xiàn)時(shí)什么仅炊。