真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Java中怎么解決分布式事務

這篇文章給大家介紹Java中怎么解決分布式事務,內(nèi)容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

創(chuàng)新互聯(lián)公司是一家專業(yè)提供四川企業(yè)網(wǎng)站建設,專注與網(wǎng)站建設、做網(wǎng)站、H5開發(fā)、小程序制作等業(yè)務。10年已為四川眾多企業(yè)、政府機構(gòu)等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進行中。

簡述

分布式事務指事務的操作位于不同的節(jié)點上,需要保證事務的 AICD 特性。

例如在下單場景下,庫存和訂單如果不在同一個節(jié)點上,就涉及分布式事務。

解決方案

在分布式系統(tǒng)中,要實現(xiàn)分布式事務,無外乎那幾種解決方案。

一、兩階段提交(2PC)

兩階段提交(Two-phase Commit,2PC),通過引入?yún)f(xié)調(diào)者(Coordinator)來協(xié)調(diào)參與者的行為,并最終決定這些參與者是否要真正執(zhí)行事務。

1. 運行過程

1.1 準備階段

協(xié)調(diào)者詢問參與者事務是否執(zhí)行成功,參與者發(fā)回事務執(zhí)行結(jié)果。

Java中怎么解決分布式事務

1.2 提交階段

如果事務在每個參與者上都執(zhí)行成功,事務協(xié)調(diào)者發(fā)送通知讓參與者提交事務;否則,協(xié)調(diào)者發(fā)送通知讓參與者回滾事務。

需要注意的是,在準備階段,參與者執(zhí)行了事務,但是還未提交。只有在提交階段接收到協(xié)調(diào)者發(fā)來的通知后,才進行提交或者回滾。

Java中怎么解決分布式事務

2. 存在的問題

2.1 同步阻塞 所有事務參與者在等待其它參與者響應的時候都處于同步阻塞狀態(tài),無法進行其它操作。

2.2 單點問題 協(xié)調(diào)者在 2PC 中起到非常大的作用,發(fā)生故障將會造成很大影響。特別是在階段二發(fā)生故障,所有參與者會一直等待狀態(tài),無法完成其它操作。

2.3 數(shù)據(jù)不一致 在階段二,如果協(xié)調(diào)者只發(fā)送了部分 Commit 消息,此時網(wǎng)絡發(fā)生異常,那么只有部分參與者接收到 Commit 消息,也就是說只有部分參與者提交了事務,使得系統(tǒng)數(shù)據(jù)不一致。

2.4 太過保守 任意一個節(jié)點失敗就會導致整個事務失敗,沒有完善的容錯機制。

二、補償事務(TCC)

TCC 其實就是采用的補償機制,其核心思想是:針對每個操作,都要注冊一個與其對應的確認和補償(撤銷)操作。它分為三個階段:

  • Try 階段主要是對業(yè)務系統(tǒng)做檢測及資源預留

  • Confirm 階段主要是對業(yè)務系統(tǒng)做確認提交,Try階段執(zhí)行成功并開始執(zhí)行 Confirm階段時,默認 Confirm階段是不會出錯的。即:只要Try成功,Confirm一定成功。

  • Cancel 階段主要是在業(yè)務執(zhí)行錯誤,需要回滾的狀態(tài)下執(zhí)行的業(yè)務取消,預留資源釋放。

舉個例子,假入 Bob 要向 Smith 轉(zhuǎn)賬,思路大概是:我們有一個本地方法,里面依次調(diào)用

  1. 首先在 Try 階段,要先調(diào)用遠程接口把 Smith 和 Bob 的錢給凍結(jié)起來。

  2. 在 Confirm 階段,執(zhí)行遠程調(diào)用的轉(zhuǎn)賬的操作,轉(zhuǎn)賬成功進行解凍。

  3. 如果第2步執(zhí)行成功,那么轉(zhuǎn)賬成功,如果第二步執(zhí)行失敗,則調(diào)用遠程凍結(jié)接口對應的解凍方法 (Cancel)。

優(yōu)點: 跟2PC比起來,實現(xiàn)以及流程相對簡單了一些,但數(shù)據(jù)的一致性比2PC也要差一些

缺點: 缺點還是比較明顯的,在2,3步中都有可能失敗。TCC屬于應用層的一種補償方式,所以需要程序員在實現(xiàn)的時候多寫很多補償?shù)拇a,在一些場景中,一些業(yè)務流程可能用TCC不太好定義及處理。

三、本地消息表(異步確保)

本地消息表與業(yè)務數(shù)據(jù)表處于同一個數(shù)據(jù)庫中,這樣就能利用本地事務來保證在對這兩個表的操作滿足事務特性,并且使用了消息隊列來保證最終一致性。

  1. 在分布式事務操作的一方完成寫業(yè)務數(shù)據(jù)的操作之后向本地消息表發(fā)送一個消息,本地事務能保證這個消息一定會被寫入本地消息表中。

  2. 之后將本地消息表中的消息轉(zhuǎn)發(fā)到 Kafka 等消息隊列中,如果轉(zhuǎn)發(fā)成功則將消息從本地消息表中刪除,否則繼續(xù)重新轉(zhuǎn)發(fā)。

  3. 在分布式事務操作的另一方從消息隊列中讀取一個消息,并執(zhí)行消息中的操作。

Java中怎么解決分布式事務

優(yōu)點: 一種非常經(jīng)典的實現(xiàn),避免了分布式事務,實現(xiàn)了最終一致性。

缺點: 消息表會耦合到業(yè)務系統(tǒng)中,如果沒有封裝好的解決方案,會有很多雜活需要處理。

四、MQ 事務消息

有一些第三方的MQ是支持事務消息的,比如RocketMQ,他們支持事務消息的方式也是類似于采用的二階段提交,但是市面上一些主流的MQ都是不支持事務消息的,比如 RabbitMQ 和 Kafka 都不支持。

以阿里的 RocketMQ 中間件為例,其思路大致為:

第一階段Prepared消息,會拿到消息的地址。第二階段執(zhí)行本地事務,第三階段通過第一階段拿到的地址去訪問消息,并修改狀態(tài)。

也就是說在業(yè)務方法內(nèi)要想消息隊列提交兩次請求,一次發(fā)送消息和一次確認消息。如果確認消息發(fā)送失敗了RocketMQ會定期掃描消息集群中的事務消息,這時候發(fā)現(xiàn)了Prepared消息,它會向消息發(fā)送者確認,所以生產(chǎn)方需要實現(xiàn)一個check接口,RocketMQ會根據(jù)發(fā)送端設置的策略來決定是回滾還是繼續(xù)發(fā)送確認消息。這樣就保證了消息發(fā)送與本地事務同時成功或同時失敗。

Java中怎么解決分布式事務

優(yōu)點: 實現(xiàn)了最終一致性,不需要依賴本地數(shù)據(jù)庫事務。

缺點: 實現(xiàn)難度大,主流MQ不支持,RocketMQ事務消息部分代碼也未開源。

關于Java中怎么解決分布式事務就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。


網(wǎng)頁題目:Java中怎么解決分布式事務
網(wǎng)址分享:http://weahome.cn/article/pcocci.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部