国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

還不懂分布式事務:帶你深入剖析TCC實現原理

云計算 分布式
TCC模型將事務分為Try、Confirm和Cancel三個階段,使得事務處理更加靈活和可控,保證了數據的一致性,減少了2PC資源鎖定時間過長的問題。

TCC概念

常見的分布式事務實現方案有以下幾種:兩階段提交(2PC)、三階段提交(3PC)、TCC(Try-Confirm-Cancel)、補償事務(Saga)、MQ事務消息等。 由于2PC資源鎖定時間較長,性能較差,難以擴展。TCC旨在解決這些問題,TCC是一種補償型事務模式,通過將每個事務操作分為三個階段:嘗試(Try)、確認(Confirm)和取消(Cancel),不僅優化了事務的執行流程,還提高了系統的整體效率和彈性。

TCC流程

TCC的核心思想在于將事務的每個操作拆分為三個明確的階段:嘗試(Try)、確認(Confirm)和取消(Cancel)。這三個階段各自承擔不同的職責,確保事務在分布式環境中能夠安全且一致地執行。

  • Try 階段

在這個階段,事務參與者將執行所有必要的檢查,并預留必需的資源來保證事務可以順利完成。例如,在電商場景,當用戶嘗試購買商品時,系統將在Try階段檢查商品庫存,預留所需數量的商品。這個階段是整個TCC流程中的準備步驟,它不會做任何實際的業務處理,只是確保后續的Confirm階段可以無障礙地執行。

  • Confirm 階段

只有當所有參與者的Try階段成功完成后,才會進入Confirm階段。在這個階段,系統將正式執行業務操作,使用在Try階段預留的資源。繼續舉例電商場景,如果用戶的支付成功,系統將在Confirm階段正式從庫存中扣除商品,完成交易。這一步驟確保了事務的最終一致性和數據的正確性。

  • Cancel 階段

如果在Try階段或Confirm階段中的任何一個環節發生錯誤,或者某些業務條件未得到滿足,整個事務將進入Cancel階段。在這個階段,所有已經預留的資源將被釋放,所有在Try階段所做的準備工作將被撤銷。例如,如果用戶決定取消購買,或者支付未成功,預留的商品庫存將被釋放,以便其他用戶購買。

電商場景介紹

舉一個常見的電商場景,用戶購買商品,點擊支付后。這時候交易系統需要做的操作是:

  1. 更新訂單狀態為“已支付”
  2. 扣減庫存
  3. 增加用戶積分

圖片圖片

電商系統一般采用微服務架構,上述三個操作分別需要調用三個服務完成。流程如下:

  1. 訂單服務,更新訂單狀態為“已支付”
  2. 庫存服務,扣減庫存
  3. 積分服務,增加用戶積分

如果這三個操作在一個服務中,就可以使用本地事務保證訂單、庫存、積分數據的一致性,但是現在需要調用三個服務,就無法保證數據的一致性了。 如果更新訂單狀態為“已支付”成功了,但是扣減庫存失敗了,其他用戶就可以繼續購買商品,可能會出現超賣問題,這時候就需要引入分布式事務,用來保證分布式系統中數據的一致性。

TCC落地電商場景

把上述電商場景引入TCC事務之后,就變成以下情況。

  • Try階段實現

Try階段負責資源的預檢查和預留,分別調用三個服務凍結資源:

  1. 訂單服務,更新訂單狀態為“支付中”
  2. 庫存服務,凍結庫存(庫存表中,新增一個凍結庫存的字段)
  3. 積分服務,預增加用戶積分(積分表,新增一個預增加積分的字段)

圖片圖片

庫存表中,新增了一個凍結庫存的字段。在商品詳情頁面展示剩余庫存數量的時候,需要減去凍結庫存,防止超賣。

  • Confirm 階段

當Try階段都執行成功的時候,就進入Confirm階段,負責確認資源。流程如下:

  1. 訂單服務,更新訂單狀態為“已支付”
  2. 庫存服務,把凍結庫存扣減到剩余庫存上(update 剩余庫存=剩余庫存-凍結庫存,凍結庫存=0)
  3. 積分服務,把預增加積分加到總積分上(udpate 總積分=總積分+預增加積分,預增加積分=0)

圖片圖片

  • Cancel階段

當Try階段任何一個操作失敗,就進入Cancel階段,負責回滾資源。流程如下:

  1. 訂單服務,更新訂單狀態為“已取消”
  2. 庫存服務,釋放凍結的庫存
  3. 積分服務,釋放預增加積分

圖片圖片

TCC問題

上述只是理想情況,在實踐的過程中會遇到以下三大問題,影響TCC事務的安全性。

  1. Confirm/Cancel操作失敗問題
  2. 空回滾問題
  3. 懸掛問題

針對每個問題,我們思考一下相應的解決方案。

1. Confirm/Cancel操作失敗問題在執行完Try階段之后,進入到Confirm或者Cancel階段,可能由于服務問題或者網絡問題,Confirm或者Cancel操作不一定能成功,通常采用的辦法是不斷重試,要求Confirm和Cancel接口要支持冪等。

2. 空回滾問題空回滾問題是指Try階段某個服務的Try操作沒有執行成功或者沒有執行,進入Cancel階段,就執行Cancel操作回滾資源,導致數據錯亂。 常用的解決方案是Cancel操作前增加事務狀態檢查。

  • 在 Try 操作開始時,設置事務狀態為 TRYING。
  • 如果 Try 操作成功,更新狀態為 TRIED。
  • 在 Cancel 操作執行前,檢查狀態。如果狀態不是 TRIED,就不執行 Cancel 操作。

3. 懸掛問題懸掛問題是指 Cancel 操作比 Try 操作先完成。通常出現的原因是由于網絡延遲,例如:由于調用Try操作耗時較長,出現網絡超時,導致Try操作調用失敗,就進入Cancel階段,執行Cancel操作,而此時Try操作還在執行,最后結果是Cancel操作執行成功后,Try操作又執行成功,出現“懸掛”問題。

解決方案有以下幾種:

  1. 與空回滾解決方案類似,Cancel操作前增加事務狀態檢查。
  • 在 Try 操作開始時,設置事務狀態為 TRYING。
  • 如果 Try 操作成功,更新狀態為 TRIED。
  • 在 Cancel 操作執行前,檢查狀態。如果狀態不是 TRIED,就不執行 Cancel 操作或者延遲執行。
  1. Try操作引入重試機制

如果調用Try操作超時,可以進行有限次重試,而不是立即執行Cancel操作,可以減少因為網絡超時而導致的懸掛問題。這里要求Try接口也要支持冪等操作。

  1. 增加同步機制

可以使用分布式鎖來控制Try和Cancel操作的執行順序。

總結

TCC模型將事務分為Try、Confirm和Cancel三個階段,使得事務處理更加靈活和可控,保證了數據的一致性,減少了2PC資源鎖定時間過長的問題。但是也引入了一些新問題:

  1. 代碼侵入嚴重。Try、Confirm和Cancel三個階段的事務操作都要耦合在業務邏輯中,耦合性較高。
  2. 設計復雜,開發成本較高。對于TCC引入的冪等操作、空回滾問題、懸掛問題,都需要架構設計的時候考慮相應的解決方案。

需要開發人員自行評估使用成本。

責任編輯:武曉燕 來源: 一燈架構
相關推薦

2018-11-23 09:25:00

TCC分布式事務

2024-12-09 09:35:00

2024-10-09 14:14:07

2021-06-08 12:46:27

分布式阿里TCC

2025-04-30 10:44:02

2023-05-12 08:02:43

分布式事務應用

2022-06-21 08:27:22

Seata分布式事務

2022-06-27 08:21:05

Seata分布式事務微服務

2022-01-12 10:02:02

TCC模式 Seata

2025-05-07 00:10:00

分布式事務TCC模式

2024-06-12 09:06:48

2024-06-04 10:58:30

2022-07-10 20:24:48

Seata分布式事務

2021-03-17 00:05:50

分布式事務提交

2020-04-28 12:18:08

Seata模式分布式

2019-08-19 10:24:33

分布式事務數據庫

2024-01-26 13:17:00

rollbackMQ訂單系統

2022-07-20 06:55:10

TCC分布式事務微服務

2025-03-25 10:29:52

2025-01-15 08:34:00

分布式事務服務
點贊
收藏

51CTO技術棧公眾號

亚洲国产精品99| 亚洲激情免费观看| 久久国产福利| 一区二区三区在线观看动漫| 日韩欧美在线1卡| 8x8ⅹ国产精品一区二区二区| 亚洲国产精品嫩草影院久久av| 精品国产乱码一区二区三区四区 | 欧美在线视频网| yellow字幕网在线| 狠狠色狠狠色合久久伊人| 产国精品偷在线| 欧美挤奶吃奶水xxxxx| 在线看国产精品| 成年人视频在线看| 91综合视频| 欧美日韩电影在线播放| 免费av片在线观看一道本| 老**午夜毛片一区二区三区| 亚州欧美日韩中文视频| 亚洲国产精品91| 亚洲精品国产精品国自产| 福利片在线观看| 秋霞欧美视频| 欧洲国产精品| 精品国产一区二区三区四区阿崩| 久久精品国产99国产| 欧美 日韩精品| 亚洲二区视频| 国产经典一区二区| 欧美aaaaaaaaaaaa| 成人久久久久久久久| 国产亚洲视频中文字幕视频| 中文天堂在线观看| 欧美军同video69gay| 69堂免费精品视频在线播放| 亚洲乱码日产精品bd| 超黄网站在线观看| 中文字幕国产日韩| 日本午夜精品久久久久| 欧美精品第1页| 国产99精品| 欧美精彩一区二区三区| 成人黄色a**站在线观看| 午夜老司机精品| 久久99在线观看| 香蕉视频免费在线播放| 国产精品丝袜视频| 成人av电影在线| 欧美在线va视频| 粉嫩av一区二区三区天美传媒 | 国产精品欧美久久久久无广告| 久草综合在线观看| 亚洲国产综合在线观看| 亚洲欧美中文日韩在线| 欧美性猛交xxx高清大费中文| 亚洲国产天堂网精品网站| 成人性生交大片免费看网站| 视频国产一区二区三区| 中文字幕无码不卡免费视频| 久久久久人妻精品一区三寸| 久久影院中文字幕| 免费一区视频| 亚洲熟妇无码一区二区三区| 亚洲狼人国产精品| 日韩黄色三级| 99国产在线视频| 国产高潮免费视频| 老司机久久99久久精品播放免费| 日本二区视频| 久久午夜激情| 欧美一进一出视频| 成年人网站在线| 日韩av在线最新| www.一区| 2018国产精品视频| 欧美日韩国产亚洲一区| 中文字幕日韩一区二区三区| 国产日韩精品一区二区浪潮av| 国产偷激情在线| 欧美三级视频在线| 成人福利片在线| 国产精品美腿一区在线看| 国产日韩高清一区二区三区在线| 一区二区三区一级片| 国产视频亚洲色图| 六十路在线观看| 亚洲一品av免费观看| 天堂俺去俺来也www久久婷婷| 高清不卡日本v二区在线| 国产99久久久国产精品免费看| 91福利电影| 日韩视频免费观看高清完整版 | 在线成人中文字幕| 日韩高清影视在线观看| 国模一区二区三区私拍视频| 91免费国产在线观看| 91福利在线视频| 久久精品国产欧美亚洲人人爽| 亚洲国产精品日韩专区av有中文| av动漫在线播放| 亚洲成av人在线观看| 欧美色网一区| 国产网站在线| 国产成人综合av| 国产精品乡下勾搭老头1| 成人一区二区av| xf在线a精品一区二区视频网站| 2020中文字幕在线| 日韩免费一区二区| 天堂av一区二区三区在线播放| 91免费高清视频| 一区二区三区视频免费观看| 久久国产精品免费视频| 大香伊人久久精品一区二区| 精品sm在线观看| 成人高清网站| 午夜免费久久看| 午夜在线视频| 欧美色爱综合网| avav在线播放| 国产999精品久久久久久绿帽| 国产精品视频男人的天堂| 狠狠躁夜夜躁人人躁婷婷91| 一级毛片免费视频| 日韩不卡在线观看| 亚洲一级淫片| 无限资源日本好片| 日韩精品一区二区在线| 国产欧美高清视频在线| 69sex久久精品国产麻豆| 亚洲三区欧美一区国产二区| 日本激情视频在线播放| 91高清视频在线免费观看| 风间由美性色一区二区三区| 超碰在线99| 日本视频一区二区不卡| 日韩欧美国产视频| 亚洲免费成人| aa国产成人| 六月丁香婷婷激情| 色综合久久九月婷婷色综合| 特黄特色欧美大片| 69国产精品视频| 永久免费毛片在线播放不卡| 欧美女优在线视频| 影音先锋可以看的网站| 精品免费99久久| 老司机久久99久久精品播放免费| av一区和二区| 天天揉久久久久亚洲精品| 激情视频免费网站| 这里只有精品久久| 巨乳诱惑日韩免费av| 亚洲高清成人| 欧美成人精品三级网站| 国产精品乱码| 亚洲性猛交xxxxwww| 99久久精品国产一区二区三区| 日韩免费影院| 精品国产乱码久久久久久88av| 亚洲制服丝袜av| 欧美韩国日本在线| 午夜精品蜜臀一区二区三区免费 | 国语自产偷拍精品视频偷 | 亚洲日本在线观看视频| 午夜精品一区二区在线观看 | 日本人体一区二区| 欧美日韩国产天堂| 欧美日韩国产精品一区二区亚洲| 四虎精品成人影院观看地址| 国产精品一区二区三区毛片淫片| 有坂深雪av一区二区精品| 欧美精品一区二区三区中文字幕| 污黄视频在线看| 国产 高清 精品 在线 a| 欧美精品久久一区二区三区 | 97视频国产在线| 亚洲同性同志一二三专区| 国产一区二区精品福利地址| 亚洲精品无码专区在线播放| 精品国产一区二区三区日日嗨 | 丝袜诱惑一区二区| 四虎影院一区二区| 久久九九免费视频| 亚洲精品自拍动漫在线| 国产日产精品_国产精品毛片| 中文字幕视频免费在线观看| 国产一区二区三区四区五区在线| 欧美成人一区二区三区| 国产91综合一区在线观看| 日韩一区二区三区在线看| 日本特黄a级高清免费大片| 91在线观看免费高清完整版在线观看 | 成人久久精品视频| 欧美日韩在线播| 狠狠色丁香久久婷婷综| 久久久久九九精品影院| 欧美18一12sex性处hd| 精品在线观看一区二区|