摘要:最終一致性二基于的分布式事務補償機制序列圖異常場景處理預創建訂單失敗如果實際預創建訂單成功訂單定時補償機制定時刪除這部分訂單不影響數據一致性下單失敗預扣減庫存失敗如果預扣減庫存真實失敗則下單失敗訂單由定時補償機制定時刪除其它應用參照場景的處
最終一致性(二) 基于MQ的分布式事務補償機制 序列圖 異常場景處理
預創建訂單失敗:如果實際預創建訂單成功,訂單定時補償機制,定時刪除這部分訂單,不影響數據一致性,下單失敗
預扣減庫存失敗:如果預扣減庫存真實失敗,則下單失敗(訂單由定時補償機制定時刪除,其它應用參照場景4的處理方式,下單失敗;如果實際預扣減庫存成功,參照場景4的處理方式,下單失敗
實際創建訂單失敗:如果創建訂單真實失敗(不需要發送下單失敗消息,防止實際創建訂單成功場景)
,訂單的預處理數據通過訂單的定時補償機制嘗試刪除(需要考慮事務處理時間,將超過某個時間范圍該事務還處于預處理狀態的訂單刪除),下單失敗;如果實際創建訂單成功,其它應用參照場景4的處理方式,下單成功(提示用戶下單失敗)
發送訂單創建成功消息失敗/庫存服務由于各種原因沒有接到下單成功消息:庫存服務定時輪詢處理數據(需要考慮事務處理時間,將超過某個時間范圍該事務還處于預處理狀態的訂單篩選出來),詢問訂單服務改訂單Id對應的訂單是否創建成功,根據訂單創建成功與否選取相應的事務補償機制
和TCC的比較TCC是把所有的訂單創建步驟平等看待,只要有一個失敗,整個下單流程全部失敗(比較TCC里面的confirm失敗和基于MQ實際創建訂單失敗的補償難易程度)
TCC是通過發消息給TCC服務器,然后由TCC服務調用應用服務;基于MQ的分布式事務補償機制,是通過將消息發送到MQ,然后由應用自己去監聽MQ的事件
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/21778.html
摘要:最終一致性二基于的分布式事務補償機制序列圖異常場景處理預創建訂單失敗如果實際預創建訂單成功訂單定時補償機制定時刪除這部分訂單不影響數據一致性下單失敗預扣減庫存失敗如果預扣減庫存真實失敗則下單失敗訂單由定時補償機制定時刪除其它應用參照場景的處 最終一致性(二) 基于MQ的分布式事務補償機制 序列圖 showImg(/img/bVzeHX); 異常場景處理 預創建訂單失敗:如果實際預創建...
摘要:最終一致性一簡介是由支付寶架構師提供的一種柔性解決分布式事務解決方案主要包括三個步驟流程的關鍵流程如下圖以下單和扣減庫存為例子預生成訂單失敗了為什么要通過執行預處理數據回滾可能預生成訂單成功但是接口返回失敗超時失敗所以預處理在某些情況下是有 最終一致性(一) TCC 簡介 TCC是由支付寶架構師提供的一種柔性解決分布式事務解決方案,主要包括三個步驟:showImg(/img/bVzc6...
摘要:為程序員金三銀四精心挑選的余道面試題與答案,歡迎大家向我推薦你在面試過程中遇到的問題我會把大家推薦的問題添加到下面的常用面試題清單中供大家參考。 為Java程序員金三銀四精心挑選的300余道Java面試題與答案,歡迎大家向我推薦你在面試過程中遇到的問題,我會把大家推薦的問題添加到下面的常用面試題清單中供大家參考。 前兩天寫的以下博客,大家比較認可,熱度不錯,希望可以幫到準備或者正在參加...
2PC(兩階段事務提交) 兩階段事務提交簡化圖 showImg(/img/bVsV61); 兩階段事務提交異常點 節點本身故障(比如Down機) 節點之間通信故障 兩階段事務提交錯誤點分析 showImg(/img/bVsV56); 說明 圖中有問號的條目,是我不確定的地方,但是不影響這個分布式事務的結果 圖中的感嘆號條目,個人感覺其實也是允許先發消息再記錄日志的,但是如果這樣子做以后發生D...
摘要:以兩階段提交來說,主持人收到一個提案請求,打電話跟每個組員詢問是否通過并統計回復,然后將最后決定打電話通知各組員。三階段提交即是引入了另一個步驟,主持人打電話跟組員通知請準備通過提案,以避免沒人知道真實決定而造成決定不一致的失業危機。 3PC 以兩階段提交來說,主持人收到一個提案請求,打電話跟每個組員詢問是否通過并統計回復,然后將最后決定打電話通知各組員。要是主持人在跟第一位組員通完電...
閱讀 578·2023-04-25 21:29
閱讀 1104·2023-04-25 21:27
閱讀 1044·2021-11-25 09:43
閱讀 1077·2021-09-29 09:43
閱讀 3613·2021-09-03 10:30
閱讀 2853·2019-08-29 15:26
閱讀 2803·2019-08-29 12:52
閱讀 1741·2019-08-29 11:10