精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

分布式事務(wù)框架Seata客戶端的使用

云計(jì)算 分布式
在選用分布式事務(wù)模式時(shí),需要根據(jù)具體業(yè)務(wù)場(chǎng)景和對(duì)一致性的需求做出選擇。每種模式都有其優(yōu)勢(shì)和局限,沒有絕對(duì)的“最佳”選擇。對(duì)于開發(fā)者來說,了解各模式的內(nèi)部機(jī)制和可能的性能影響是非常重要的。

Seata (Simple Extensible Autonomous Transaction Architecture) 是一種開源的分布式事務(wù)解決方案,致力于在微服務(wù)架構(gòu)下提供高效且對(duì)業(yè)務(wù)無侵入的分布式事務(wù)服務(wù)。Seata 能夠幫助開發(fā)者輕松地解決在微服務(wù)架構(gòu)下服務(wù)間的數(shù)據(jù)一致性問題。

圖片圖片

在分布式系統(tǒng)中,一個(gè)業(yè)務(wù)操作通常會(huì)涉及到多個(gè)服務(wù)的協(xié)作,這些服務(wù)可能會(huì)對(duì)不同的數(shù)據(jù)庫進(jìn)行操作。傳統(tǒng)的分布式事務(wù)解決方案(如2PC,即兩階段提交)雖然能夠保證強(qiáng)一致性,但卻在性能和可用性方面存在不小的挑戰(zhàn)。因此,Seata 提出了一種基于AT、TCC、SAGA、XA等模式的輕量級(jí)分布式事務(wù)協(xié)調(diào)方案。

Seata 確實(shí)支持多種分布式事務(wù)模式,包括 AT(自動(dòng)補(bǔ)償事務(wù))、TCC(Try-Confirm-Cancel)、SAGA 和 XA(擴(kuò)展的兩階段提交協(xié)議)。每種模式都有自己的使用場(chǎng)景和特點(diǎn):

1. AT模式(Auto-Compensating Transaction)

圖片圖片

  • 適用場(chǎng)景:簡單的CRUD操作,不需要特殊處理的業(yè)務(wù)邏輯。
  • 特點(diǎn):

易于使用,開發(fā)者不需要編寫額外的補(bǔ)償邏輯,Seata 會(huì)自動(dòng)為每個(gè)分支事務(wù)生成撤銷(回滾)邏輯。

性能較好,因?yàn)樗鼫p少了準(zhǔn)備階段的通信開銷。

通過行鎖和UNDO_LOG(回濾日志),加鎖和數(shù)據(jù)改動(dòng)被記錄下來,保證在出現(xiàn)錯(cuò)誤時(shí)可以回滾事務(wù)。

@Service
public class OrderService {
    @GlobalTransactional(timeoutMills = 300000, name = "create-order")
    public void createOrder(Order order, Payment payment, Inventory inventory) {
        // 更新庫存
        inventoryService.reduceStock(inventory);


        // 創(chuàng)建支付記錄
        paymentService.pay(payment);


        // 創(chuàng)建訂單
        orderRepository.save(order);
    }
}

按照官方配置AT模式后,在方法前面添加GlobalTransactional注解。


AT模式的主要思想就是通過一個(gè)中間層進(jìn)行協(xié)調(diào)事務(wù)的確認(rèn)和回滾操作,將相應(yīng)的操作記錄在例如數(shù)據(jù)庫表里面,在提交后進(jìn)行事務(wù)的信息的刪除,再通過一個(gè)全局鎖來避免資源的競爭。其方式對(duì)業(yè)務(wù)代碼不需要侵入。

2. TCC模式(Try-Confirm-Cancel)

圖片圖片

  • 適用場(chǎng)景:業(yè)務(wù)邏輯較為復(fù)雜,或者需要明確的業(yè)務(wù)補(bǔ)償操作。
  • 特點(diǎn):

分為三個(gè)操作:Try(嘗試執(zhí)行業(yè)務(wù))、Confirm(確認(rèn)執(zhí)行業(yè)務(wù))、Cancel(取消執(zhí)行業(yè)務(wù)),業(yè)務(wù)邏輯被拆分成這三部分。

開發(fā)者需要自行實(shí)現(xiàn)這三個(gè)操作,提供更強(qiáng)的業(yè)務(wù)手動(dòng)控制能力。

具體的業(yè)務(wù)操作和補(bǔ)償邏輯是可見的,有助于處理復(fù)雜的業(yè)務(wù)場(chǎng)景。

//定義接口實(shí)現(xiàn)注解
@LocalTCC
public interface PaymentService {
    // "try" 方法,準(zhǔn)備資源,比如凍結(jié)用戶資金
    @TwoPhaseBusinessAction(name = "preparePay", commitMethod = "commitPay", rollbackMethod = "cancelPay")
    boolean preparePay(BusinessActionContext context, String accountId, double amount);
    // "confirm" 方法,確認(rèn)并實(shí)際扣除凍結(jié)的資金
    boolean commitPay(BusinessActionContext context);
    // "cancel" 方法,取消操作,解凍之前凍結(jié)的資金
    boolean cancelPay(BusinessActionContext context);
}


//然后,為接口提供一個(gè)實(shí)現(xiàn)類,并實(shí)現(xiàn)try、confirm和cancel方法:
@Service
public class PaymentServiceImpl implements PaymentService {
    @Autowired
    private AccountRepository accountRepository;


    @Override
    public boolean preparePay(BusinessActionContext context, String accountId, double amount) {
        // 實(shí)現(xiàn)資金的凍結(jié)邏輯
        // ...
        return true;
    }
    @Override
    public boolean commitPay(BusinessActionContext context) {
        // 實(shí)現(xiàn)實(shí)際扣除資金的邏輯
        // ...
        return true;
    }
    @Override
    public boolean cancelPay(BusinessActionContext context) {
        // 實(shí)現(xiàn)取消扣款,即解凍資金的邏輯
        // ...
        return true;
    }
}


//最后,在需要執(zhí)行TCC事務(wù)的業(yè)務(wù)邏輯中注入PaymentService并調(diào)用上述方法:
@Service
public class OrderService {
    @Autowired
    private PaymentService paymentService;
    @GlobalTransactional
    public void createOrder(Order order, String accountId, double amount) {
        // TCC try 階段
        boolean result = paymentService.preparePay(null, accountId, amount);
        if (!result) {
            throw new RuntimeException("Payment preparation failed.");
        }


        // TCC confirm 或 cancel 階段將由Seata框架根據(jù)全局事務(wù)的最終狀態(tài)自動(dòng)調(diào)用
        // ...
    }
}

其本質(zhì)的思想就是通過代碼編寫確認(rèn)機(jī)制和補(bǔ)償機(jī)制,這種方式需要對(duì)業(yè)務(wù)的代碼的侵入。

3. SAGA模式

  • 適用場(chǎng)景:長事務(wù)場(chǎng)景,例如一系列的步驟或服務(wù)調(diào)用需要在整體上保持一致性。
  • 特點(diǎn):

基于狀態(tài)機(jī)實(shí)現(xiàn),每個(gè)步驟都對(duì)應(yīng)狀態(tài)遷移過程中的一個(gè)節(jié)點(diǎn)。

不適用于標(biāo)準(zhǔn)的兩階段提交,而是將一個(gè)全局事務(wù)分解成多個(gè)局部事務(wù),通過定義前向操作和反向補(bǔ)償操作來保證整體一致性。

適用于事務(wù)執(zhí)行時(shí)間較長的業(yè)務(wù)流程,減少了鎖資源的持有時(shí)間。

// 偽代碼,僅為示例說明
StateMachineBuilder stateMachineBuilder = StateMachineBuilderFactory.create();
StateMachine stateMachine = stateMachineBuilder
    .state("Start")
    .initial("CreateOrder")
        .to("ReserveInventory").on("InventoryReserved")
        .to("CancelOrder").on("InventoryReserveFailed")
    .step("ReserveInventory")
        .to("ProcessPayment").on("PaymentProcessed")
        .to("RevertInventory").on("PaymentProcessFailed")
    .step("ProcessPayment")
        .to("End").on("Success")
    .step("CancelOrder")
    .compensateWith("CancelOrderOperation")
    .step("RevertInventory")
    .compensateWith("RevertInventoryOperation")
    .build();
stateMachine.start();

使用狀態(tài)機(jī)來進(jìn)行多事務(wù)的描述其本質(zhì)的思想就是對(duì)多事務(wù)進(jìn)行確認(rèn)和補(bǔ)償,這種也會(huì)需要對(duì)業(yè)務(wù)代碼的侵入。

4. XA模式

圖片圖片

  • 適用場(chǎng)景:需要嚴(yán)格的ACID事務(wù),并且各參與方(數(shù)據(jù)庫、消息中間件等)支持XA接口。
  • 特點(diǎn):

基于兩階段提交(2PC),第一階段是準(zhǔn)備階段,第二階段是提交或回濾階段。

實(shí)現(xiàn)了跨資源管理器的全局事務(wù)。

通常比AT模式效率低,因?yàn)樗诘谝浑A段結(jié)束時(shí)需要所有參與者就事務(wù)結(jié)果達(dá)成一致,然后在第二階段進(jìn)行提交或回滾。

將動(dòng)態(tài)的代理數(shù)據(jù)源替換成XA模式,然后和AT模式一樣,在需要的方法前面添加GlobalTransactional注解

@Service
public class OrderService {
    @Autowired
    private OrderRepository orderRepository;
    @GlobalTransactional
    public void createOrder(Order order) {
        // 此處的數(shù)據(jù)庫操作會(huì)自動(dòng)被Seata管理
        orderRepository.save(order);
        // ...其他可能涉及數(shù)據(jù)庫操作的代碼
    }
}

其本質(zhì)的思想就是與AT模式類似,但是需要基于數(shù)據(jù)庫能支持XA模式才能運(yùn)行,AT模式是在中間層進(jìn)行確認(rèn)和回滾的日志記錄,而XA模式是將記錄交給數(shù)據(jù)庫來運(yùn)行,也避免了AT模式下手動(dòng)操作數(shù)據(jù)導(dǎo)致問題。XA模式不需要侵入業(yè)務(wù)代碼。

圖片圖片

在選用分布式事務(wù)模式時(shí),需要根據(jù)具體業(yè)務(wù)場(chǎng)景和對(duì)一致性的需求做出選擇。每種模式都有其優(yōu)勢(shì)和局限,沒有絕對(duì)的“最佳”選擇。對(duì)于開發(fā)者來說,了解各模式的內(nèi)部機(jī)制和可能的性能影響是非常重要的。

責(zé)任編輯:武曉燕 來源: 程序員技術(shù)成長之路
相關(guān)推薦

2022-06-27 08:21:05

Seata分布式事務(wù)微服務(wù)

2022-06-21 08:27:22

Seata分布式事務(wù)

2022-03-24 07:51:27

seata分布式事務(wù)Java

2022-07-10 20:24:48

Seata分布式事務(wù)

2021-08-06 08:33:27

Springboot分布式Seata

2025-04-28 00:44:04

2023-01-06 09:19:12

Seata分布式事務(wù)

2025-04-30 10:44:02

2024-10-09 14:14:07

2021-04-23 08:15:51

Seata XA AT

2023-11-06 13:15:32

分布式事務(wù)Seata

2023-08-17 10:23:07

擴(kuò)展方案

2011-11-30 14:21:19

Java分布式緩存

2020-03-12 19:00:48

Ceph分布式存儲(chǔ)

2024-08-19 09:05:00

Seata分布式事務(wù)

2025-05-07 00:10:00

分布式事務(wù)TCC模式

2020-12-09 09:14:57

SpringCloudSeata 分布式

2022-07-03 14:03:57

分布式Seata

2020-12-08 11:43:03

Spring Clou分布式Seata

2020-04-28 12:18:08

Seata模式分布式
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

深爱五月激情网| 国内精品在线观看视频| 91资源在线视频| 中文字幕一区二区三区久久网站| 精品噜噜噜噜久久久久久久久试看| 成人性免费视频| 国产精品久久久久一区二区国产| 国产在线播放一区| 茄子视频成人在线| 欧美黄片一区二区三区| 久久不见久久见中文字幕免费| 91精品国产高清一区二区三区蜜臀| 国产精品无码一区二区在线| 免费大片在线观看www| 成人免费视频app| 国产日韩欧美日韩大片| 久久久国产高清| 亚洲成人tv| 国产午夜精品全部视频播放| 18深夜在线观看免费视频| 日韩成人亚洲| 午夜视频一区二区| 法国空姐在线观看免费| 国产高清av在线| 97久久超碰国产精品| 91人人爽人人爽人人精88v| 东京热一区二区三区四区| 欧美日本不卡| 蜜臀久久99精品久久久久久宅男 | 日韩高清免费在线| 污视频在线观看免费网站| 69堂免费精品视频在线播放| 精品国产999| 无码粉嫩虎白一线天在线观看| 国产乱色在线观看| 国产精品久久久久国产精品日日| 欧美韩国日本精品一区二区三区| 人妻一区二区三区| 国产成人高清视频| 亚洲www视频| 97人妻精品一区二区三区动漫| 天堂在线亚洲视频| 日韩av电影院| 五月婷婷激情视频| 亚洲一区日韩| 欧美性在线视频| 色婷婷在线观看视频| 亚洲无线视频| 欧美激情中文字幕乱码免费| 青青操视频在线播放| 91精品国产调教在线观看| 色噜噜狠狠狠综合曰曰曰88av| 亚洲精品成人av久久| 成人一级毛片| 中文字幕精品久久| 青青青视频在线播放| 四虎成人av| 久久久精品久久久| 欧美成人三级在线观看| 欧美一区二区| 欧美精品videos| 一区二区三区视频免费看| 亚洲毛片av| 日产精品久久久一区二区福利 | 欧美日韩中文一区| 天堂av手机在线| 麻豆精品一区| 亚洲第一福利网站| 精品久久久久久中文字幕人妻最新| 香蕉久久精品日日躁夜夜躁| 亚洲一二三在线| 色哟哟一一国产精品| 你懂的网址国产 欧美| 国内精品久久久久| 99re国产在线| 九九久久精品视频| 国产伦精品一区二区| 深夜影院在线观看| 国产精品成人午夜| 欧美日韩激情四射| a一区二区三区| 欧美视频日韩视频在线观看| 亚洲视频在线不卡| 欧美自拍视频| 日韩资源在线观看| 久久久91视频| 视频在线观看国产精品| 91九色单男在线观看| 天堂av2024| 国产精品国产成人国产三级 | 视频一区在线播放| 91麻豆国产精品| 色偷偷在线观看| 国产精品久久久久影院| 97视频在线免费| 成人看片毛片免费播放器| 欧美大片一区二区| 日韩精品电影一区二区三区| 欧美午夜免费影院| 国产女同一区二区| 色视频在线观看| 夜夜嗨av一区二区三区四季av| 成人久久久久久久久| 免费观看亚洲天堂| 这里只有精品久久| 中文字幕精品三级久久久| 国产一区二区免费在线| 日韩欧美视频第二区| 国产桃色电影在线播放| 欧美日韩亚洲丝袜制服| 风间由美一二三区av片| 欧美黄免费看| 91九色国产在线| av基地在线| 精品国产福利视频| 日本人添下边视频免费| 手机在线电影一区| 国产精品久久中文| 国内精品一区视频| 精品久久久国产精品999| 奇米777在线| 五月天久久777| 国产精品欧美久久久| 欧美日韩国产综合视频| 香蕉乱码成人久久天堂爱免费| 99热这里只有精品2| 999国产精品| 国产精品久久久久久久久久久久久| 色就是色亚洲色图| 五月天激情综合| 人妖粗暴刺激videos呻吟| 欧美精品99| 亚洲最大福利网站| av网站在线看| 91精品国产综合久久久久久久久久 | 亚洲一区日韩精品| 精品国产乱码久久久久久果冻传媒| 91超碰中文字幕久久精品| 可以免费看毛片的网站| 亚洲福利视频一区| 日韩少妇一区二区| 亚洲精选在线| 免费国产在线精品一区二区三区| 日本乱码一区二区三区不卡| 亚洲精品美女在线观看| 国产精品午夜影院| 26uuu亚洲综合色| 黄色片久久久久| 久操精品在线| 国产精品女人网站| 成人国产免费电影| 欧美一级片在线| 久草免费新视频| 成人a区在线观看| 凹凸国产熟女精品视频| 精品欧美久久| 成人黄色免费片| av免费在线观看网址| 日韩免费成人网| 日本一区二区三区免费视频| 久久一区二区视频| 国产一二三区av| 91精品亚洲| 国产伦精品一区二区三区视频免费 | 国产欧美一区二区三区精品观看| 国产高清视频一区三区| 日本蜜桃在线观看| 日韩精品一区在线| 日韩一区二区视频在线| 欧美激情一区二区在线| 香蕉视频xxxx| 99在线观看免费视频精品观看| 欧美资源一区| 日韩色性视频| 国语自产精品视频在线看抢先版图片 | 国产视频一区二区在线播放| 久久久久五月天| 国产日本在线视频| 日韩免费成人网| 无码免费一区二区三区| 亚洲免费观看高清完整版在线观看熊 | www.好吊操| 国产一区二区三区四区五区传媒 | 青青免费在线视频| 在线不卡a资源高清| www.youjizz.com亚洲| 久久久久国产精品厨房| www.久久com| 老司机亚洲精品| av片在线免费| 欧美偷拍综合| 国产在线一区二区三区播放| 97精品国产99久久久久久免费| 欧美大片免费看| 77导航福利在线| 日韩av中文字幕在线免费观看| 亚洲一区在线观| 狠狠色狠狠色综合日日五| 久久国产高清视频| 久久久综合视频| 色欲无码人妻久久精品| 男女男精品视频| 男女激情无遮挡| 一本一本久久a久久综合精品| 久久免费一区| 视频一区日韩精品| 成人日韩av在线| 日韩电影网站| 91精品国产91久久久久福利| www久久日com| 上原亚衣av一区二区三区| 日本一区高清| 亚洲福利视频网| 国产suv精品一区二区69| 欧美在线影院一区二区| 欧美精品韩国精品| 天天综合色天天综合色h| 免费又黄又爽又色的视频| 中文字幕日韩一区| 三年中国中文观看免费播放| 99re热这里只有精品免费视频| 超级砰砰砰97免费观看最新一期| 久久精品国产免费| 男女污污的视频| 久久精品日产第一区二区 | 久久er99精品| www.激情小说.com| 日韩和欧美一区二区三区| www.浪潮av.com| 亚洲国内精品| 草草视频在线免费观看| 国内精品嫩模av私拍在线观看| 国产美女视频免费| 国产精品99久久精品| 亚洲精品欧洲精品| 日韩精品2区| 一区二区三区av在线| 热久久天天拍国产| 亚欧精品在线| 色999国产精品| 在线天堂一区av电影| 国产精品久久久久一区二区三区厕所 | 亚洲成人精品在线观看| 久久在线视频精品| 亚洲一区二区三区小说| 久久久久久久极品内射| 亚洲福利一二三区| 天堂中文字幕在线观看| 色先锋久久av资源部| 欧美日韩 一区二区三区| 欧美在线免费观看亚洲| 伊人亚洲综合网| 这里是久久伊人| 亚洲精品视频专区| 日韩av资源在线播放| 国产一区二区影视| 精品国产依人香蕉在线精品| 怡红院在线播放| 午夜精品一区二区三区av| 91精品产国品一二三产区| 国产精品视频区| 精品国产18久久久久久二百| 成人做爰66片免费看网站| 九九热hot精品视频在线播放| 精品久久中出| blacked蜜桃精品一区| aaa免费在线观看| 在线国产日韩| 香蕉视频网站入口| 国产精品996| 日韩片在线观看| 中文字幕一区二区在线播放| 久久婷婷综合国产| 色欧美乱欧美15图片| 国产同性人妖ts口直男| 亚洲国产精品久久91精品| 国产大学生校花援交在线播放| 欧美成人免费网| 亚洲精品mv| 91网站免费看| 亚洲欧洲av| 99热都是精品| 新狼窝色av性久久久久久| 亚洲一二三不卡| 26uuu国产日韩综合| www深夜成人a√在线| 欧美日韩午夜视频在线观看| 6—12呦国产精品| 国产视频久久网| 99热国产在线| 国产v综合v亚洲欧美久久| 国产亚洲亚洲国产一二区| 欧美大陆一区二区| 中文字幕日韩欧美精品高清在线| 久久精品.com| 成人aaaa免费全部观看| 亚洲色图日韩精品| 色综合久久天天| 你懂的网站在线| 久久视频在线观看免费| 日韩在线短视频| 国产精品久久久久久久久久直播| 欧美xxav| 成人小视频在线看| 成人免费看的视频| www.超碰在线观看| 欧美视频在线一区二区三区| 少妇性bbb搡bbb爽爽爽欧美| 欧美第一黄色网| 欧美国产视频| 日韩啊v在线| 国产精品久久久久久模特| 在线成人免费av| 中文子幕无线码一区tr| 一级黄色av片| 亚洲精品一区二区久| 国内老司机av在线| 91手机在线播放| 91成人观看| 欧美成人福利在线观看| 国产校园另类小说区| 黄色在线观看国产| 亚洲精品第一国产综合精品| 日本片在线观看| 1卡2卡3卡精品视频| 亚洲国产一区二区三区在线播放| 日本在线一二三区| 欧美激情一二三区| 亚洲男人天堂网址| 亚洲图片欧洲图片av| 日本韩国欧美| 任我爽在线视频精品一| 另类亚洲自拍| 欧美做受xxxxxⅹ性视频| 欧美视频在线观看免费网址| 天堂在线免费av| 欧美综合在线观看| 美日韩中文字幕| 久久综合久久色| 久久久久久9999| 国语对白做受69按摩| 色777狠狠综合秋免鲁丝| 日韩黄色三级| 400部精品国偷自产在线观看| 激情久久久久久久久久久久久久久久| 亚洲精品自拍视频在线观看| 欧美日产在线观看| 18av在线视频| 国产精品露出视频| 亚洲一区亚洲| 性欧美一区二区| 欧美日韩精品专区| free性欧美hd另类精品| 国产精品对白刺激久久久| 亚洲欧洲日本mm| 精品久久久久久中文字幕人妻最新| 一本色道久久综合狠狠躁的推荐 | 精品久久久中文字幕人妻| 久久久久一本一区二区青青蜜月 | 亚洲伊人婷婷| 国产a久久麻豆| www.国产高清| 国产一级揄自揄精品视频| 91精品国产一区二区在线观看| 国产91在线亚洲| 久久色成人在线| 又骚又黄的视频| 欧美精品情趣视频| 欧美顶级毛片在线播放| 久久久国产欧美| 亚洲激情网站免费观看| 亚洲av成人无码久久精品老人| 国产精品成人播放| 女人色偷偷aa久久天堂| 蜜桃精品成人影片| 欧美日韩午夜影院| 波多野结衣在线高清| 日韩一区不卡| 国产成人av影院| 91麻豆精品在线| 欧美高清视频在线| 免费视频国产一区| 日韩高清在线一区二区| 黑人巨大精品欧美一区免费视频 | 午夜国产福利在线| 国产午夜精品在线| 美女在线一区二区| 日韩黄色三级视频| 日韩视频在线免费观看| 欧美天堂影院| 亚洲图片 自拍偷拍| 色综合天天天天做夜夜夜夜做| av片在线观看| 亚洲精品高清视频| av亚洲精华国产精华精华 | 国产乱码一区二区三区| 无码人妻丰满熟妇奶水区码| 久久久久国产视频| 久久综合99| 亚洲自拍偷拍图|