欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

連續(xù)調(diào)用多個(gè)外部系統(tǒng)寫接口保證數(shù)據(jù)一致性的思路

 更新時(shí)間:2018年12月11日 15:04:34   作者:Sam哥哥  
今天小編就為大家分享一篇關(guān)于連續(xù)調(diào)用多個(gè)外部系統(tǒng)寫接口保證數(shù)據(jù)一致性的思路,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧

概述

某些場(chǎng)景下,我們將業(yè)務(wù)數(shù)據(jù)落地之前,是需要先調(diào)用外部系統(tǒng)的多個(gè)寫接口,當(dāng)這些寫接口都操作成功了,我們才將業(yè)務(wù)數(shù)據(jù)落地到自己本地的數(shù)據(jù)庫里面。比如說:

public void updateProductInfo(Product product) {
  //1、將商品價(jià)格更新到價(jià)格系統(tǒng)
  priceService.updatePrice(product);
  //2、將庫存信息更新庫存系統(tǒng)
  stockService.updateStock(product);
  //3、將商品更新到本地?cái)?shù)據(jù)庫
  productService.updateProduct(product);
}

就上面這個(gè)例子(例子是虛構(gòu)的,只是為了說明問題而已),它的執(zhí)行路徑有幾種:

  • 1、調(diào)用價(jià)格系統(tǒng)、庫存系統(tǒng)的操作以及保存數(shù)據(jù)到本地DB都正常;
  • 2、調(diào)用價(jià)格系統(tǒng)接口的時(shí)候就拋異常了;
  • 3、調(diào)用價(jià)格系統(tǒng)接口正常,但是調(diào)用庫存系統(tǒng)的接口有異常;
  • 4、調(diào)用價(jià)格系統(tǒng)和庫存系統(tǒng)的接口都正常了,但是將商品數(shù)據(jù)更新到本地?cái)?shù)據(jù)庫出現(xiàn)異常。

如果是第一和第二這兩種情況,無需考慮數(shù)據(jù)一致性問題,但是如果出現(xiàn)了第三和第四這兩種情況,我們就得根據(jù)業(yè)務(wù)實(shí)際情況,考慮如何保證數(shù)據(jù)的一致性。

這里說的保證數(shù)據(jù)一致性,必須是由調(diào)用方來保證的,服務(wù)端是無法保證的。

重試和操作日志

以上面提到的第三種情況來說明一下。

調(diào)用價(jià)格系統(tǒng)接口正常,但是調(diào)用庫存系統(tǒng)的接口有異常。

庫存接口允許重試

如果庫存系統(tǒng)接口是冪等的,那么調(diào)用方可以使用重試的機(jī)制,多調(diào)用幾次,比如說3次。如果還是不成功,那之前價(jià)格系統(tǒng)接口的操作就得走反向操作,進(jìn)行現(xiàn)場(chǎng)恢復(fù)。

庫存接口不允許重試

價(jià)格系統(tǒng)接口的操作得走反向操作,進(jìn)行現(xiàn)場(chǎng)恢復(fù)

要實(shí)現(xiàn)反向操作,恢復(fù)現(xiàn)場(chǎng),有一種辦法是使用分布式事務(wù),但是實(shí)現(xiàn)起來實(shí)在太復(fù)雜了,性能也不好。可以嘗試使用操作日志來恢復(fù)現(xiàn)場(chǎng)。比如說,價(jià)格系統(tǒng)調(diào)用成功了,把這個(gè)操作狀態(tài)以及相關(guān)的業(yè)務(wù)數(shù)據(jù)記錄起來,當(dāng)庫存操作失敗后,利用操作日志里的數(shù)據(jù),將之前的價(jià)格操作恢復(fù)回來。這個(gè)恢復(fù)操作,價(jià)格系統(tǒng)可以單獨(dú)提供出一個(gè)接口。

如果恢復(fù)現(xiàn)場(chǎng)的操作也失敗了,這個(gè)時(shí)候只能人工介入解決了。沒其他辦法了。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

相關(guān)文章

  • Spring框架事務(wù)屬性中事務(wù)隔離級(jí)別與傳播行為全面講解

    Spring框架事務(wù)屬性中事務(wù)隔離級(jí)別與傳播行為全面講解

    這篇文章主要介紹了Spring框架聲明式事務(wù)的事務(wù)隔離級(jí)別和事務(wù)傳播行為,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-11-11
  • Java8中字符串處理庫strman-java的使用示例

    Java8中字符串處理庫strman-java的使用示例

    除了Java本身的字符串處理方式外,我們還可以使用Apache Common Langs里的StringUtils來簡(jiǎn)化String的操作。但以上兩種方式對(duì)于我們?nèi)粘>幊讨凶钊菀着龅降淖址幚韥碚f,仍然顯得有些不足。所以這篇文章給大家介紹Java8中字符串處理庫strman-java的使用。
    2016-09-09
  • java查找無向連通圖中兩點(diǎn)間所有路徑的算法

    java查找無向連通圖中兩點(diǎn)間所有路徑的算法

    這篇文章主要介紹了java查找無向連通圖中兩點(diǎn)間所有路徑的算法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • Java垃圾回收機(jī)制簡(jiǎn)述

    Java垃圾回收機(jī)制簡(jiǎn)述

    這篇文章主要為大家詳細(xì)介紹了Java垃圾回收機(jī)制的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • @JsonProperty和@JSONField注解的區(qū)別解析(最新)

    @JsonProperty和@JSONField注解的區(qū)別解析(最新)

    Jackson是一款優(yōu)秀的JSON解析庫,添加了依賴之后就可以使用對(duì)應(yīng)的注解,讓我們能夠自由的將Java對(duì)象和JSON做轉(zhuǎn)換,這篇文章主要介紹了@JsonProperty和@JSONField注解的區(qū)別,需要的朋友可以參考下
    2024-04-04
  • Java中的==使用方法詳解

    Java中的==使用方法詳解

    這篇文章主要給大家介紹了關(guān)于Java中的==使用方法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-09-09
  • 詳解高性能緩存Caffeine原理及實(shí)戰(zhàn)

    詳解高性能緩存Caffeine原理及實(shí)戰(zhàn)

    Caffeine是基于Java 8開發(fā)的,提供了近乎最佳命中率的高性能本地緩存組件,Spring5開始不再支持Guava Cache,改為使用Caffeine。Caffeine提供的內(nèi)存緩存使用參考Google guava的API
    2021-06-06
  • SWT(JFace) FTP客戶端實(shí)現(xiàn)

    SWT(JFace) FTP客戶端實(shí)現(xiàn)

    SWT(JFace)小制作:FTP客戶端實(shí)現(xiàn)
    2009-06-06
  • SpringBoot集成極光推送的實(shí)現(xiàn)代碼

    SpringBoot集成極光推送的實(shí)現(xiàn)代碼

    工作中經(jīng)常會(huì)遇到服務(wù)器向App推送消息的需求,一般企業(yè)中選擇用極光推送的比較多,本文就介紹了SpringBoot集成極光推送的實(shí)現(xiàn)代碼,感興趣的可以了解一下
    2023-08-08
  • Java匿名內(nèi)部類的寫法示例

    Java匿名內(nèi)部類的寫法示例

    這篇文章主要給大家介紹了關(guān)于Java匿名內(nèi)部類的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08

最新評(píng)論