日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

高并发下的接口幂等性解决方案!

發(fā)布時(shí)間:2025/3/21 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 高并发下的接口幂等性解决方案! 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

一、背景

我們實(shí)際系統(tǒng)中有很多操作,是不管做多少次,都應(yīng)該產(chǎn)生一樣的效果或返回一樣的結(jié)果。

例如:

  • 前端重復(fù)提交選中的數(shù)據(jù),應(yīng)該后臺只產(chǎn)生對應(yīng)這個(gè)數(shù)據(jù)的一個(gè)反應(yīng)結(jié)果。

  • 我們發(fā)起一筆付款請求,應(yīng)該只扣用戶賬戶一次錢,當(dāng)遇到網(wǎng)絡(luò)重發(fā)或系統(tǒng)bug重發(fā),也應(yīng)該只扣一次錢;

  • 發(fā)送消息,也應(yīng)該只發(fā)一次,同樣的短信發(fā)給用戶,用戶會哭的;

  • 創(chuàng)建業(yè)務(wù)訂單,一次業(yè)務(wù)請求只能創(chuàng)建一個(gè),創(chuàng)建多個(gè)就會出大問題。

  • 等等很多重要的情況,這些邏輯都需要冪等的特性來支持。

    二、冪等性概念

    冪等(idempotent、idempotence)是一個(gè)數(shù)學(xué)與計(jì)算機(jī)學(xué)概念,常見于抽象代數(shù)中。

    在編程中.一個(gè)冪等操作的特點(diǎn)是其任意多次執(zhí)行所產(chǎn)生的影響均與一次執(zhí)行的影響相同。冪等函數(shù),或冪等方法,是指可以使用相同參數(shù)重復(fù)執(zhí)行,并能獲得相同結(jié)果的函數(shù)。

    這些函數(shù)不會影響系統(tǒng)狀態(tài),也不用擔(dān)心重復(fù)執(zhí)行會對系統(tǒng)造成改變。例如,“getUsername()和setTrue()”函數(shù)就是一個(gè)冪等函數(shù).

    更復(fù)雜的操作冪等保證是利用唯一交易號(流水號)實(shí)現(xiàn).

    我的理解:冪等就是一個(gè)操作,不論執(zhí)行多少次,產(chǎn)生的效果和返回的結(jié)果都是一樣的

    三、技術(shù)方案

    1. 查詢操作?查詢一次和查詢多次,在數(shù)據(jù)不變的情況下,查詢結(jié)果是一樣的。select是天然的冪等操作

    2. 刪除操作?刪除操作也是冪等的,刪除一次和多次刪除都是把數(shù)據(jù)刪除。(注意可能返回結(jié)果不一樣,刪除的數(shù)據(jù)不存在,返回0,刪除的數(shù)據(jù)多條,返回結(jié)果多個(gè))

    3.唯一索引,防止新增臟數(shù)據(jù)?比如:支付寶的資金賬戶,支付寶也有用戶賬戶,每個(gè)用戶只能有一個(gè)資金賬戶,怎么防止給用戶創(chuàng)建資金賬戶多個(gè),那么給資金賬戶表中的用戶ID加唯一索引,所以一個(gè)用戶新增成功一個(gè)資金賬戶記錄

    要點(diǎn):?唯一索引或唯一組合索引來防止新增數(shù)據(jù)存在臟數(shù)據(jù) (當(dāng)表存在唯一索引,并發(fā)時(shí)新增報(bào)錯時(shí),再查詢一次就可以了,數(shù)據(jù)應(yīng)該已經(jīng)存在了,返回結(jié)果即可)

    4. token機(jī)制,防止頁面重復(fù)提交

    業(yè)務(wù)要求:

    頁面的數(shù)據(jù)只能被點(diǎn)擊提交一次

    發(fā)生原因:由于重復(fù)點(diǎn)擊或者網(wǎng)絡(luò)重發(fā),或者nginx重發(fā)等情況會導(dǎo)致數(shù)據(jù)被重復(fù)提交

    解決辦法:集群環(huán)境:采用token加redis(redis單線程的,處理需要排隊(duì)) 單JVM環(huán)境:采用token加redis或token加jvm內(nèi)存

    處理流程:

  • 數(shù)據(jù)提交前要向服務(wù)的申請token,token放到redis或jvm內(nèi)存,token有效時(shí)間

  • 提交后后臺校驗(yàn)token,同時(shí)刪除token,生成新的token返回

  • token特點(diǎn):

    要申請,一次有效性,可以限流

    注意:redis要用刪除操作來判斷token,刪除成功代表token校驗(yàn)通過,如果用select+delete來校驗(yàn)token,存在并發(fā)問題,不建議使用

    5. 悲觀鎖?獲取數(shù)據(jù)的時(shí)候加鎖獲取

    select * from table_xxx where id='xxx' for update;

    注意:id字段一定是主鍵或者唯一索引,不然是鎖表,會死人的

    悲觀鎖使用時(shí)一般伴隨事務(wù)一起使用,數(shù)據(jù)鎖定時(shí)間可能會很長,根據(jù)實(shí)際情況選用

    6. 樂觀鎖?樂觀鎖只是在更新數(shù)據(jù)那一刻鎖表,其他時(shí)間不鎖表,所以相對于悲觀鎖,效率更高。

    樂觀鎖的實(shí)現(xiàn)方式多種多樣可以通過version或者其他狀態(tài)條件:

    1、通過版本號實(shí)現(xiàn)

    update?table_xxx?set?name=#name#,version=version+1?where?version=#version#

    如下圖(來自網(wǎng)上):

    2、通過條件限制

    update?tablexxx?set?avaiamount=avaiamount-#subAmount#?where?avaiamount-#subAmount#?>=?0

    要求:quality-#subQuality# >= ,這個(gè)情景適合不用版本號,只更新是做數(shù)據(jù)安全校驗(yàn),適合庫存模型,扣份額和回滾份額,性能更高

    注意:樂觀鎖的更新操作,最好用主鍵或者唯一索引來更新,這樣是行鎖,否則更新時(shí)會鎖表,上面兩個(gè)sql改成下面的兩個(gè)更好

    update?tablexxx?set?name=#name#,version=version+1?where?id=#id#?and?version=#version#update?tablexxx?set?avaiamount=avaiamount-#subAmount#?where?id=#id#?and?avai_amount-#subAmount#?>=?0

    7. 分布式鎖?還是拿插入數(shù)據(jù)的例子,如果是分布是系統(tǒng),構(gòu)建全局唯一索引比較困難,例如唯一性的字段沒法確定

    這時(shí)候可以引入分布式鎖,通過第三方的系統(tǒng)(redis或zookeeper),在業(yè)務(wù)系統(tǒng)插入數(shù)據(jù)或者更新數(shù)據(jù),獲取分布式鎖,然后做操作,之后釋放鎖

    這樣其實(shí)是把多線程并發(fā)的鎖的思路,引入多多個(gè)系統(tǒng),也就是分布式系統(tǒng)中得解決思路。

    要點(diǎn):某個(gè)長流程處理過程要求不能并發(fā)執(zhí)行,可以在流程執(zhí)行之前根據(jù)某個(gè)標(biāo)志(用戶ID+后綴等)獲取分布式鎖,其他流程執(zhí)行時(shí)獲取鎖就會失敗,也就是同一時(shí)間該流程只能有一個(gè)能執(zhí)行成功,執(zhí)行完成后,釋放分布式鎖(分布式鎖要第三方系統(tǒng)提供)

    8. select + insert?并發(fā)不高的后臺系統(tǒng),或者一些任務(wù)JOB,為了支持冪等,支持重復(fù)執(zhí)行,簡單的處理方法是,先查詢下一些關(guān)鍵數(shù)據(jù),判斷是否已經(jīng)執(zhí)行過,在進(jìn)行業(yè)務(wù)處理,就可以了

    注意:核心高并發(fā)流程不要用這種方法

    9. 狀態(tài)機(jī)冪等?在設(shè)計(jì)單據(jù)相關(guān)的業(yè)務(wù),或者是任務(wù)相關(guān)的業(yè)務(wù),肯定會涉及到狀態(tài)機(jī)(狀態(tài)變更圖),就是業(yè)務(wù)單據(jù)上面有個(gè)狀態(tài),狀態(tài)在不同的情況下會發(fā)生變更,一般情況下存在有限狀態(tài)機(jī)

    如果狀態(tài)機(jī)已經(jīng)處于下一個(gè)狀態(tài),這時(shí)候來了一個(gè)上一個(gè)狀態(tài)的變更,理論上是不能夠變更的,這樣的話,保證了有限狀態(tài)機(jī)的冪等。

    注意:訂單等單據(jù)類業(yè)務(wù),存在很長的狀態(tài)流轉(zhuǎn),一定要深刻理解狀態(tài)機(jī),對業(yè)務(wù)系統(tǒng)設(shè)計(jì)能力提高有很大幫助

    10. 對外提供接口的api如何保證冪等

    如銀聯(lián)提供的付款接口:需要接入商戶提交付款請求時(shí)附帶:source來源,seq序列號

    source+seq在數(shù)據(jù)庫里面做唯一索引,防止多次付款,(并發(fā)時(shí),只能處理一個(gè)請求)

    重點(diǎn)對外提供接口為了支持冪等調(diào)用,接口有兩個(gè)字段必須傳,一個(gè)是來源source,一個(gè)是來源方序列號seq,這個(gè)兩個(gè)字段在提供方系統(tǒng)里面做聯(lián)合唯一索引

    這樣當(dāng)?shù)谌秸{(diào)用時(shí),先在本方系統(tǒng)里面查詢一下,是否已經(jīng)處理過,返回相應(yīng)處理結(jié)果;沒有處理過,進(jìn)行相應(yīng)處理,返回結(jié)果。

    注意,為了冪等友好,一定要先查詢一下,是否處理過該筆業(yè)務(wù),不查詢直接插入業(yè)務(wù)系統(tǒng),會報(bào)錯,但實(shí)際已經(jīng)處理了。

    總結(jié)

    冪等性應(yīng)該是合格程序員的一個(gè)基因,在設(shè)計(jì)系統(tǒng)時(shí),是首要考慮的問題,尤其是在像支付寶,銀行,互聯(lián)網(wǎng)金融公司等涉及的都是錢的系統(tǒng),既要高效,數(shù)據(jù)也要準(zhǔn)確,所以不能出現(xiàn)多扣款,多打款等問題,這樣會很難處理,用戶體驗(yàn)也不好

    總結(jié)

    以上是生活随笔為你收集整理的高并发下的接口幂等性解决方案!的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 狠狠艹视频 | 亚洲五月婷婷 | 亚洲成人一二三 | 另类亚洲激情 | 欧美成人免费在线观看视频 | 国产三级一区 | 天海翼av在线播放 | 日日噜噜夜夜狠狠久久丁香五月 | www超碰在线| 欧美性猛交xxxx黑人猛交 | 欧美重口另类 | 国产成人小视频 | 亚洲一区二区三区电影在线观看 | 中文字幕在线高清 | 国产激情无码一区二区三区 | 日本免费在线 | 国产精品一区二区无码对白 | 特级精品毛片免费观看 | 色乱码一区二区三区在线男奴 | 国产精品日日夜夜 | 天天操天天草 | 久草福利视频 | 99嫩草| 日本在线三级 | 亚洲30p| 91国内在线视频 | 亚洲影视在线观看 | 国产无套在线观看 | 日本黄色网址大全 | 欧洲成人在线视频 | 国产精品视频导航 | 一级黄色大片视频 | 中文字幕无线精品亚洲乱码一区 | 国产又粗又黄又爽视频 | 成人网在线视频 | 瑟瑟视频在线观看 | 婷婷激情五月 | www.国产一区二区 | 亚洲天堂av中文字幕 | 国产精品传媒一区二区 | 九九热精品免费视频 | 国产香蕉在线观看 | 香蕉91视频| 国产亚洲一区二区三区不卡 | 成人在线视频免费播放 | 国产经典三级在线 | 久久99精品国产91久久来源 | 国产123区在线观看 91国产一区二区 | 亚洲欧美日韩在线看 | 91九色高潮 | 青青青国内视频在线观看软件 | 深夜视频在线观看 | 欧美丰满老妇熟乱xxxxyyy | 91看片免费看 | 伊人久久婷婷 | 在线看国产 | 久久久影院 | 国产一区午夜 | 性xxxxxxxxx18欧美| 欧美黄色大片在线观看 | 成人福利av | 沟厕沟厕近拍高清视频 | 伊人亚洲精品 | 国产成人在线观看 | 欧美在线色 | 超薄肉色丝袜一区二区 | 免费成人深夜夜 | 香蕉在线播放 | 免费观看国产视频 | 一区二区自拍偷拍 | 午夜激情视频网站 | jjzz黄色片| 97黄色片 | 日韩18p| 国产精品久久久精品 | 青青伊人久久 | 青草视频在线观看免费 | 在线黄av| 91重口味 | 欧美乱妇高清无乱码 | 妖精视频在线观看 | 性三级视频 | 中文字幕在线观看第二页 | 亚洲欧美日本另类 | 激情久久五月天 | 亚洲av综合av一区二区三区 | 亚洲欧美日韩一区二区三区四区 | 国产手机精品视频 | 乌克兰少妇性做爰 | 国产性色av| 免费看又黄又无码的网站 | 国产精品美女在线 | 日韩av在线网址 | 日韩三级不卡 | 日韩成人一区二区 | 日本狠狠爱 | 国产精品-色哟哟 | 91中出| 日本免费一区二区三区四区 |