日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Java接口冪等性設計原理解析

瀏覽:75日期:2022-08-31 18:42:35

在微服務架構下,我們在完成一個訂單流程時經常遇到下面的場景:

一個訂單創建接口,第一次調用超時了,然后調用方重試了一次 在訂單創建時,我們需要去扣減庫存,這時接口發生了超時,調用方重試了一次 當這筆訂單開始支付,在支付請求發出之后,在服務端發生了扣錢操作,接口響應超時了,調用方重試了一次 一個訂單狀態更新接口,調用方連續發送了兩個消息,一個是已創建,一個是已付款。但是你先接收到已付款,然后又接收到了已創建 在支付完成訂單之后,需要發送一條短信,當一臺機器接收到短信發送的消息之后,處理較慢。消息中間件又把消息投遞給另外一臺機器處理

以上問題,就是在單體架構轉成微服務架構之后,帶來的問題。當然不是說單體架構下沒有這些問題,在單體架構下同樣要避免重復請求。但是出現的問題要比這少得多。

為了解決以上問題,就需要保證接口的冪等性,接口的冪等性實際上就是接口可重復調用,在調用方多次調用的情況下,接口最終得到的結果是一致的。有些接口可以天然的實現冪等性,比如查詢接口,對于查詢來說,你查詢一次和兩次,對于系統來說,沒有任何影響,查出的結果也是一樣。

除了查詢功能具有天然的冪等性之外,增加、更新、刪除都要保證冪等性。那么如何來保證冪等性呢?

全局唯一ID

如果使用全局唯一ID,就是根據業務的操作和內容生成一個全局ID,在執行操作前先根據這個全局唯一ID是否存在,來判斷這個操作是否已經執行。如果不存在則把全局ID,存儲到存儲系統中,比如數據庫、redis等。如果存在則表示該方法已經執行。

從工程的角度來說,使用全局ID做冪等可以作為一個業務的基礎的微服務存在,在很多的微服務中都會用到這樣的服務,在每個微服務中都完成這樣的功能,會存在工作量重復。另外打造一個高可靠的冪等服務還需要考慮很多問題,比如一臺機器雖然把全局ID先寫入了存儲,但是在寫入之后掛了,這就需要引入全局ID的超時機制。

使用全局唯一ID是一個通用方案,可以支持插入、更新、刪除業務操作。但是這個方案看起來很美但是實現起來比較麻煩,下面的方案適用于特定的場景,但是實現起來比較簡單。

去重表

這種方法適用于在業務中有唯一標的插入場景中,比如在以上的支付場景中,如果一個訂單只會支付一次,所以訂單ID可以作為唯一標識。這時,我們就可以建一張去重表,并且把唯一標識作為唯一索引,在我們實現時,把創建支付單據和寫入去去重表,放在一個事務中,如果重復創建,數據庫會拋出唯一約束異常,操作就會回滾。

插入或更新

這種方法插入并且有唯一索引的情況,比如我們要關聯商品品類,其中商品的ID和品類的ID可以構成唯一索引,并且在數據表中也增加了唯一索引。這時就可以使用InsertOrUpdate操作。在mysql數據庫中如下:

insert into goods_category (goods_id,category_id,create_time,update_time)values(#{goodsId},#{categoryId},now(),now())on DUPLICATE KEY UPDATEupdate_time=now()

多版本控制

這種方法適合在更新的場景中,比如我們要更新商品的名字,這時我們就可以在更新的接口中增加一個版本號,來做冪等

boolean updateGoodsName(int id,String newName,int version);

在實現時可以如下

update goods set name=#{newName},version=#{version} where id=#{id} and version<${version}

狀態機控制

這種方法適合在有狀態機流轉的情況下,比如就會訂單的創建和付款,訂單的付款肯定是在之前,這時我們可以通過在設計狀態字段時,使用int類型,并且通過值類型的大小來做冪等,比如訂單的創建為0,付款成功為100。付款失敗為99

在做狀態機更新時,我們就這可以這樣控制

update `order` set status=#{status} where id=#{id} and status<#{status}

以上就是保證接口冪等性的一些方法。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久亚洲欧洲| 国产日韩欧美三级| 97se亚洲| 亚洲电影在线一区二区三区| 国产精品二区不卡| 国产日韩欧美中文在线| 亚洲精品一区二区在线播放∴| 欧美国产91| 欧美激情麻豆| 国产欧美日韩影院| 亚洲免费专区| av成人国产| 国产成人免费精品| 国产精品视频首页| 久久精品 人人爱| 中文字幕日韩欧美精品高清在线| 极品日韩av| 99久久久久国产精品| 日韩欧美午夜| 欧美gv在线| 欧美男人天堂| 国产一区二区三区网| 麻豆成人av在线| 日韩高清一级| 日韩一区二区三区免费视频| 亚洲精品视频一二三区| 天堂俺去俺来也www久久婷婷| 免费在线观看日韩欧美| 中文字幕亚洲精品乱码| 日韩午夜视频在线| 国产欧美一级| 九九九精品视频| 国内揄拍国内精品久久| 国产黄大片在线观看| 日本免费一区二区三区四区| 激情国产在线| 亚洲精品在线影院| 欧美午夜精彩| 久久亚洲成人| 国产综合精品| 亚洲欧美视频| 日产欧产美韩系列久久99| 国产日韩欧美| 狠狠久久伊人| 国产精品蜜芽在线观看| 国产99久久| 亚洲在线免费| 日本伊人午夜精品| 欧美私人啪啪vps| 久久a爱视频| 黄色aa久久| 日本伊人午夜精品| 国产精品极品| 国产一区二区三区四区五区| 日韩高清欧美| 激情综合在线| 亚洲欧美日本国产| 久久xxx视频| 久久精品123| 色8久久久久| 欧美xxxx性| 欧美综合另类| 日韩欧美2区| 成人在线视频中文字幕| 午夜免费一区| 日韩精品中文字幕一区二区| 国产精品宾馆| 亚洲手机视频| 88久久精品| 欧美成人综合| 国产极品模特精品一二| 日本欧洲一区二区| 精品三级久久| 麻豆久久久久久| 亚洲免费成人av在线| 久久九九电影| 美女久久久精品| 中文一区一区三区免费在线观 | 欧美日韩激情| 麻豆91精品视频| 久久福利精品| 久久久久亚洲| 久久精品国产福利| 97久久中文字幕| 国产亚洲网站| 亚洲国内欧美| av高清一区| 久久免费精品| 国产精品久久国产愉拍| 中文字幕日本一区二区| 午夜欧美精品久久久久久久| 国产资源在线观看入口av| 欧美日韩一区二区高清| 中文字幕一区二区精品区| 欧美精选一区二区三区| 国产成人免费av一区二区午夜| 日韩成人精品一区二区三区| 亚洲在线免费| 一本一道久久a久久精品蜜桃| 中文在线а√天堂| 久久精品国产99国产| 国产欧美亚洲一区| 热久久久久久| 最近国产精品视频| 亚洲欧美日本视频在线观看| 蜜桃国内精品久久久久软件9| 亚洲三级欧美| 国产成人久久| 久久久久久婷| 国产精品蜜芽在线观看| 国产精品2区| 国产精品网站在线看| 国产情侣一区在线| 青青草国产成人99久久| 日韩精品免费视频人成| 蜜桃视频一区二区三区在线观看| 亚洲一区网站| 一区在线免费| 国产视频亚洲| 丝瓜av网站精品一区二区 | 日韩精品a在线观看91| 久久亚洲精品伦理| 亚洲欧美日韩国产| 在线视频精品| 亚洲一区黄色| 美女久久网站| 亚洲综合中文| 欧美另类中文字幕| 国产欧美精品| 国产精品第一| 日产精品一区二区| 欧美成人精品三级网站| 桃色一区二区| 国产一区二区三区自拍| 99在线精品免费视频九九视| 日韩影院免费视频| 日韩高清电影免费| 欧美日韩亚洲一区三区| 久久久久97| 欧美三级精品| 亚洲国内精品| 鲁大师影院一区二区三区| 亚久久调教视频| 国产色99精品9i| 精品国产午夜| 亚洲h色精品| 久久亚洲色图| 欧美片第1页综合| 97欧美在线视频| 免费av一区二区三区四区| 亚洲影视一区二区三区| 欧美国产另类| 日韩欧美另类一区二区| 91精品高清| 日韩精品一区二区三区免费视频 | 欧美午夜精品一区二区三区电影| 亚洲一区二区三区中文字幕在线观看| 日韩视频二区| 亚洲尤物在线| 亚洲精品在线国产| 国产精品探花在线观看| 麻豆高清免费国产一区| 精品美女在线视频| 欧美日韩在线二区| 一本一道久久a久久| 国产精品99久久免费观看| 中文字幕人成乱码在线观看| 欧美精品羞羞答答| 婷婷成人av| 日本一区二区高清不卡| 黄页网站一区| 欧美精品福利| 久久91导航| 综合激情网...| 精品久久久久久久| 亚洲免费精品| 日韩美女一区二区三区在线观看| 老司机精品视频网| 99久久久久久中文字幕一区| 亚洲综合图色| 精品精品国产三级a∨在线| 国产韩日影视精品| 国产乱子精品一区二区在线观看 | 水蜜桃久久夜色精品一区的特点 | 日韩在线短视频| 日韩精品导航| 中文在线资源| 亚洲精品裸体| 午夜精品成人av| 日韩精品视频中文字幕| 成人久久一区| 国产精品免费不| 日韩午夜av在线| 精品福利久久久| 综合国产精品| 亚洲v在线看| 国产精品久久久久9999高清| 99xxxx成人网| 日韩大片在线| 国产精品亚洲成在人线|