成全视频在线观看免费高清,国产亚洲欧洲精品,成年人午夜免费视频,久久机热综合久久国产

銀聯(lián)刷卡機(jī)接口

瀏覽:187 發(fā)布日期:2023-04-19 00:00:00 投稿人:佚名投稿

網(wǎng)上關(guān)于銀聯(lián)刷卡機(jī)接口的刷卡知識(shí)比較多,也有關(guān)于銀聯(lián)刷卡機(jī)接口的問(wèn)題,今天第一pos網(wǎng)(www.yadikedp.com)為大家整理刷卡常見(jiàn)知識(shí),未來(lái)的我們終成一代卡神。

本文目錄一覽:

1、銀聯(lián)刷卡機(jī)接口

銀聯(lián)刷卡機(jī)接口

我們實(shí)際系統(tǒng)中有很多操作,是不管做多少次,都應(yīng)該產(chǎn)生一樣的效果或返回一樣的結(jié)果。 例如1. 前端重復(fù)提交選中的數(shù)據(jù),應(yīng)該后臺(tái)只產(chǎn)生對(duì)應(yīng)這個(gè)數(shù)據(jù)的一個(gè)反應(yīng)結(jié)果;2. 我們發(fā)起一筆付款請(qǐng)求,應(yīng)該只扣用戶(hù)賬戶(hù)一次錢(qián),當(dāng)遇到網(wǎng)絡(luò)重發(fā)或系統(tǒng)bug重發(fā),也應(yīng)該只扣一次錢(qián);3. 發(fā)送消息,也應(yīng)該只發(fā)一次,同樣的短信發(fā)給用戶(hù),用戶(hù)會(huì)哭的;4. 創(chuàng)建業(yè)務(wù)訂單,一次業(yè)務(wù)請(qǐng)求只能創(chuàng)建一個(gè),創(chuàng)建多個(gè)就會(huì)出大問(wèn)題等等很多重要的情況都需要冪等的特性來(lái)支持。

技術(shù)方案

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

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

唯一索引,防止新增臟數(shù)據(jù)。比如:支付寶的資金賬戶(hù),支付寶也有用戶(hù)賬戶(hù),每個(gè)用戶(hù)只能有一個(gè)資金賬戶(hù),怎么防止給用戶(hù)創(chuàng)建資金賬戶(hù)多個(gè),那么給資金賬戶(hù)表中的用戶(hù)ID加唯一索引,所以一個(gè)用戶(hù)新增成功一個(gè)資金賬戶(hù)記錄。要點(diǎn):唯一索引或唯一組合索引來(lái)防止新增數(shù)據(jù)存在臟數(shù)據(jù)(當(dāng)表存在唯一索引,并發(fā)時(shí)新增報(bào)錯(cuò)時(shí),再查詢(xún)一次就可以了,數(shù)據(jù)應(yīng)該已經(jīng)存在了,返回結(jié)果即可);

token機(jī)制,防止頁(yè)面重復(fù)提交。業(yè)務(wù)要求: 頁(yè)面的數(shù)據(jù)只能被點(diǎn)擊提交一次;發(fā)生原因: 由于重復(fù)點(diǎn)擊或者網(wǎng)絡(luò)重發(fā),或者nginx重發(fā)等情況會(huì)導(dǎo)致數(shù)據(jù)被重復(fù)提交;解決辦法: 集群環(huán)境采用token加redis(redis單線(xiàn)程的,處理需要排隊(duì));單JVM環(huán)境:采用token加redis或token加jvm內(nèi)存。處理流程:1. 數(shù)據(jù)提交前要向服務(wù)的申請(qǐng)token,token放到redis或jvm內(nèi)存,token有效時(shí)間;2. 提交后后臺(tái)校驗(yàn)token,同時(shí)刪除token,生成新的token返回。token特點(diǎn):要申請(qǐng),一次有效性,可以限流。注意:redis要用刪除操作來(lái)判斷token,刪除成功代表token校驗(yàn)通過(guò),如果用select+delete來(lái)校驗(yàn)token,存在并發(fā)問(wèn)題,不建議使用;

悲觀(guān)鎖——獲取數(shù)據(jù)的時(shí)候加鎖獲取。select * from table_xxx where id='xxx' for update; 注意:id字段一定是主鍵或者唯一索引,不然是鎖表,會(huì)死人的悲觀(guān)鎖使用時(shí)一般伴隨事務(wù)一起使用,數(shù)據(jù)鎖定時(shí)間可能會(huì)很長(zhǎng),根據(jù)實(shí)際情況選用;

樂(lè)觀(guān)鎖——樂(lè)觀(guān)鎖只是在更新數(shù)據(jù)那一刻鎖表,其他時(shí)間不鎖表,所以相對(duì)于悲觀(guān)鎖,效率更高。樂(lè)觀(guān)鎖的實(shí)現(xiàn)方式多種多樣可以通過(guò)version或者其他狀態(tài)條件:1. 通過(guò)版本號(hào)實(shí)現(xiàn)update table_xxx set name=#name#,version=version+1 where version=#version#如下圖(來(lái)自網(wǎng)上);2. 通過(guò)條件限制 update table_xxx set avai_amount=avai_amount-#subAmount# where avai_amount-#subAmount# >= 0要求:quality-#subQuality# >= ,這個(gè)情景適合不用版本號(hào),只更新是做數(shù)據(jù)安全校驗(yàn),適合庫(kù)存模型,扣份額和回滾份額,性能更高;

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

update table_xxx set name=#name#,version=version+1 where id=#id# and version=#version#;

update table_xxx set avai_amount=avai_amount-#subAmount# where id=#id# and avai_amount-#subAmount# >= 0;

7.分布式鎖——還是拿插入數(shù)據(jù)的例子,如果是分布是系統(tǒng),構(gòu)建全局唯一索引比較困難,例如唯一性的字段沒(méi)法確定,這時(shí)候可以引入分布式鎖,通過(guò)第三方的系統(tǒng)(redis或zookeeper),在業(yè)務(wù)系統(tǒng)插入數(shù)據(jù)或者更新數(shù)據(jù),獲取分布式鎖,然后做操作,之后釋放鎖,這樣其實(shí)是把多線(xiàn)程并發(fā)的鎖的思路,引入多多個(gè)系統(tǒng),也就是分布式系統(tǒng)中得解決思路。要點(diǎn):某個(gè)長(zhǎng)流程處理過(guò)程要求不能并發(fā)執(zhí)行,可以在流程執(zhí)行之前根據(jù)某個(gè)標(biāo)志(用戶(hù)ID+后綴等)獲取分布式鎖,其他流程執(zhí)行時(shí)獲取鎖就會(huì)失敗,也就是同一時(shí)間該流程只能有一個(gè)能執(zhí)行成功,執(zhí)行完成后,釋放分布式鎖(分布式鎖要第三方系統(tǒng)提供);

8. select + insert——并發(fā)不高的后臺(tái)系統(tǒng),或者一些任務(wù)JOB,為了支持冪等,支持重復(fù)執(zhí)行,簡(jiǎn)單的處理方法是,先查詢(xún)下一些關(guān)鍵數(shù)據(jù),判斷是否已經(jīng)執(zhí)行過(guò),在進(jìn)行業(yè)務(wù)處理,就可以了。注意:核心高并發(fā)流程不要用這種方法;

9. 狀態(tài)機(jī)冪等——在設(shè)計(jì)單據(jù)相關(guān)的業(yè)務(wù),或者是任務(wù)相關(guān)的業(yè)務(wù),肯定會(huì)涉及到狀態(tài)機(jī)(狀態(tài)變更圖),就是業(yè)務(wù)單據(jù)上面有個(gè)狀態(tài),狀態(tài)在不同的情況下會(huì)發(fā)生變更,一般情況下存在有限狀態(tài)機(jī),這時(shí)候,如果狀態(tài)機(jī)已經(jīng)處于下一個(gè)狀態(tài),這時(shí)候來(lái)了一個(gè)上一個(gè)狀態(tài)的變更,理論上是不能夠變更的,這樣的話(huà),保證了有限狀態(tài)機(jī)的冪等。注意:訂單等單據(jù)類(lèi)業(yè)務(wù),存在很長(zhǎng)的狀態(tài)流轉(zhuǎn),一定要深刻理解狀態(tài)機(jī),對(duì)業(yè)務(wù)系統(tǒng)設(shè)計(jì)能力提高有很大幫助

10. 對(duì)外提供接口的api如何保證冪等。如銀聯(lián)提供的付款接口:需要接入商戶(hù)提交付款請(qǐng)求時(shí)附帶:source來(lái)源,seq序列號(hào)

source+seq在數(shù)據(jù)庫(kù)里面做唯一索引,防止多次付款(并發(fā)時(shí),只能處理一個(gè)請(qǐng)求) 。重點(diǎn):對(duì)外提供接口為了支持冪等調(diào)用,接口有兩個(gè)字段必須傳,一個(gè)是來(lái)源source,一個(gè)是來(lái)源方序列號(hào)seq,這個(gè)兩個(gè)字段在提供方系統(tǒng)里面做聯(lián)合唯一索引,這樣當(dāng)?shù)谌秸{(diào)用時(shí),先在本方系統(tǒng)里面查詢(xún)一下,是否已經(jīng)處理過(guò),返回相應(yīng)處理結(jié)果;沒(méi)有處理過(guò),進(jìn)行相應(yīng)處理,返回結(jié)果。注意,為了冪等友好,一定要先查詢(xún)一下,是否處理過(guò)該筆業(yè)務(wù),不查詢(xún)直接插入業(yè)務(wù)系統(tǒng),會(huì)報(bào)錯(cuò),但實(shí)際已經(jīng)處理了。

四、總結(jié)

冪等與你是不是分布式高并發(fā)還有JavaEE都沒(méi)有關(guān)系。關(guān)鍵是你的操作是不是冪等的。一個(gè)冪等的操作典型如:把編號(hào)為5的記錄的A字段設(shè)置為0這種操作不管執(zhí)行多少次都是冪等的。一個(gè)非冪等的操作典型如:把編號(hào)為5的記錄的A字段增加1這種操作顯然就不是冪等的。要做到冪等性,從接口設(shè)計(jì)上來(lái)說(shuō)不設(shè)計(jì)任何非冪等的操作即可。譬如說(shuō)需求是:當(dāng)用戶(hù)點(diǎn)擊贊同時(shí),將答案的贊同數(shù)量+1。改為:當(dāng)用戶(hù)點(diǎn)擊贊同時(shí),確保答案贊同表中存在一條記錄,用戶(hù)、答案。贊同數(shù)量由答案贊同表統(tǒng)計(jì)出來(lái)。總之冪等性應(yīng)該是合格程序員的一個(gè)基因,在設(shè)計(jì)系統(tǒng)時(shí),是首要考慮的問(wèn)題,尤其是在像支付寶,銀行,互聯(lián)網(wǎng)金融公司等涉及的都是錢(qián)的系統(tǒng),既要高效,數(shù)據(jù)也要準(zhǔn)確,所以不能出現(xiàn)多扣款,多打款等問(wèn)題,這樣會(huì)很難處理,用戶(hù)體驗(yàn)也不好。

————————————————

轉(zhuǎn)自csdn

原文鏈接:https://blog.csdn.net/u011635492/java/article/details/81058153

以上就是關(guān)于銀聯(lián)刷卡機(jī)接口的知識(shí),后面我們會(huì)繼續(xù)為大家整理關(guān)于銀聯(lián)刷卡機(jī)接口的知識(shí),希望能夠幫助到大家!

轉(zhuǎn)載請(qǐng)帶上網(wǎng)址:http://www.yadikedp.com/shuaka/68106.html

版權(quán)聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶(hù)自發(fā)貢獻(xiàn),該文觀(guān)點(diǎn)僅代表作者本人。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如發(fā)現(xiàn)本站有涉嫌抄襲侵權(quán)/違法違規(guī)的內(nèi)容, 請(qǐng)發(fā)送郵件至 [email protected] 舉報(bào),一經(jīng)查實(shí),本站將立刻刪除。
聯(lián)系我們
訂購(gòu)聯(lián)系:小莉
微信聯(lián)系方式
地址:深圳市寶安區(qū)固戍聯(lián)誠(chéng)發(fā)產(chǎn)業(yè)園木星大廈

公司地址:深圳市寶安區(qū)固戍聯(lián)誠(chéng)發(fā)產(chǎn)業(yè)園木星大廈

舉報(bào)投訴 免責(zé)申明 版權(quán)申明 廣告服務(wù) 投稿須知 技術(shù)支持:第一POS網(wǎng) Copyright@2008-2030 深圳市慧聯(lián)實(shí)業(yè)有限公司 備案號(hào):粵ICP備18141915號(hào)

  • <bdo id="ogrsz"></bdo>
      1. <pre id="ogrsz"><abbr id="ogrsz"></abbr></pre>
        <p id="ogrsz"></p>
        <bdo id="ogrsz"></bdo>
        主站蜘蛛池模板: 墨玉县| 阜宁县| 玉门市| 汾西县| 噶尔县| 拉孜县| 颍上县| 邯郸市| 松阳县| 嘉义市| 瑞丽市| 增城市| 建平县| 社旗县| 肇源县| 南昌县| 武冈市| 兴义市| 泽库县| 祁连县| 临汾市| 安图县| 虞城县| 孟州市| 峡江县| 东阳市| 平顶山市| 神农架林区| 天水市| 池州市| 五家渠市| 静宁县| 潢川县| 九龙城区| 京山县| 阿坝| 阳谷县| 东方市| 九江市| 丰县| 金阳县|