淺談接口冪等性

一. 冪等的概念

  • 用在編程領(lǐng)域里, 則意為: 對同一個系統(tǒng)壕曼,使用同樣的條件,一次請求和重復(fù)的多次請求對系統(tǒng)資源的影響是一致的

  • 在數(shù)學(xué)的定義里可以簡單理解為: 在某運算下,冪等元素是指被自己重復(fù)運算的結(jié)果等于它自己的元素。 f(x) = f(f(x))


二. 冪等的場景

在我們實際的開發(fā)過程中, 例如: 支付接口調(diào)用, 交易下單等.

有以下場景:
系統(tǒng)B接口不支持冪等, A系統(tǒng)請求B系統(tǒng)支付接口進(jìn)行支付. 因網(wǎng)絡(luò)超時導(dǎo)致接口請求失敗.


三. 關(guān)于接口的冪等設(shè)計

關(guān)于以上場景, A系統(tǒng)進(jìn)行后續(xù)處理.

  • 如果將接口請求判為失敗, 顯然是不合理的. 因為,可能是在B系統(tǒng)接收到支付請求之后,進(jìn)行了扣款操作且扣款成功, 但是在接口返回時超時.
    此時如果A系統(tǒng)再向B系統(tǒng)發(fā)起支付申請重試, 對于客戶來說同一筆交易發(fā)生多次扣款, 造成客戶損失.

  • 如果將接口請求判為成功, 也不合理. 因為,可能B系統(tǒng)根本就沒有接收到支付請求, 客戶也沒法發(fā)生扣款操作, 而客戶的訂單狀態(tài)卻成功了. 對于商戶來說會造成損失.

  • 所以, 對與以上情況,都是不可取的. 正確的方式是:

    • B系統(tǒng)在接口設(shè)計時, 定義一個對于每筆訂單都是唯一的流水號編號字段, 同時在DB中對該字段維護(hù)唯一約束.
    • 若A請求B網(wǎng)絡(luò)超時, 那么A可以不更換交易流水號, 繼續(xù)請求B系統(tǒng)對超時的交易進(jìn)行重試. B系統(tǒng)在插入支付訂單前, 先檢查一下是否之前已經(jīng)處理該筆交易.
      如果未處理, 則直接交易落地, 并進(jìn)行后續(xù)處理.
      如果交易已處理,則返回給A系統(tǒng)此時的交易狀態(tài)和結(jié)果.
      假設(shè)在接口請求時發(fā)生并發(fā), B系統(tǒng)也可以通過DB的唯一約束擋住另一筆并發(fā)的交易.

四. 關(guān)于接口防并發(fā)的處理方式

1.在接口方法上使用同步鎖

  • 優(yōu)缺點: 實現(xiàn)簡單. 但是只適用于非集群環(huán)境

2.分布式鎖如redis

  • 優(yōu)缺點: 能擋住分布式系統(tǒng)的并發(fā), 但是設(shè)計相對復(fù)雜(具體實現(xiàn)可以參考:分布式鎖的實現(xiàn)).而且控制并發(fā)的代價是讓接口在集群中都是單線程形式處理業(yè)務(wù)請求, 大大犧牲的接口性能. 并不可取

2.業(yè)務(wù)字段加唯一約束

  1. 前端系統(tǒng)生成唯一性token+后端token字段落地并加唯一約束
  • 優(yōu)缺點: 方便實用

對客戶端請求排隊或者單線程都可以處理并發(fā)冪等問題,需要根據(jù)具體業(yè)務(wù)選擇合適的方案但必須前后端一起做,前端做了可以提升用戶體驗秸应,后端則可以保證數(shù)據(jù)安全。

五. 總結(jié)

//TODO

參考文章

如有問題,還請各位老師批評指正,謝謝~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末碑宴,一起剝皮案震驚了整個濱河市软啼,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌延柠,老刑警劉巖祸挪,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異贞间,居然都是意外死亡贿条,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人错森,你說我怎么就攤上這事」冢” “怎么了?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長帆调。 經(jīng)常有香客問我奠骄,道長,這世上最難降的妖魔是什么番刊? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮影锈,結(jié)果婚禮上芹务,老公的妹妹穿的比我還像新娘。我一直安慰自己鸭廷,他們只是感情好枣抱,可當(dāng)我...
    茶點故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著辆床,像睡著了一般佳晶。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上讼载,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天轿秧,我揣著相機與錄音,去河邊找鬼咨堤。 笑死菇篡,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的一喘。 我是一名探鬼主播驱还,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼凸克!你這毒婦竟也來了议蟆?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤萎战,失蹤者是張志新(化名)和其女友劉穎咐容,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體撞鹉,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡疟丙,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了鸟雏。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片享郊。...
    茶點故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖孝鹊,靈堂內(nèi)的尸體忽然破棺而出炊琉,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布苔咪,位于F島的核電站锰悼,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏团赏。R本人自食惡果不足惜箕般,卻給世界環(huán)境...
    茶點故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望舔清。 院中可真熱鬧丝里,春花似錦、人聲如沸体谒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽抒痒。三九已至幌绍,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間故响,已是汗流浹背傀广。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留被去,地道東北人主儡。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像惨缆,于是被迫代替她去往敵國和親糜值。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,614評論 2 353

推薦閱讀更多精彩內(nèi)容

  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對...
    cosWriter閱讀 11,097評論 1 32
  • 在一個方法內(nèi)部定義的變量都存儲在棧中坯墨,當(dāng)這個函數(shù)運行結(jié)束后寂汇,其對應(yīng)的棧就會被回收,此時捣染,在其方法體中定義的變量將不...
    Y了個J閱讀 4,416評論 1 14
  • http://liuxing.info/2017/06/30/Spring%20AMQP%E4%B8%AD%E6%...
    sherlock_6981閱讀 15,908評論 2 11
  • 從我有記憶開始骄瓣,外婆是一個勤勞樸實的人。 小時候耍攘,外婆家是我童年走親戚去的最多的地方榕栏。 每逢春節(jié)、端午蕾各、中秋扒磁,去外...
    時趣大叔閱讀 282評論 0 0
  • 貓和豬是好朋友。一天貓掉進(jìn)大坑兰伤,豬拿來繩子内颗,貓叫豬把繩子扔下來,結(jié)果它整捆扔了下去敦腔。貓很郁悶地說:這樣扔下來均澳,怎么...
    樂天知命love1閱讀 209評論 0 0