您好,登錄后才能下訂單哦!
這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)Spring Boot 中怎么整合 RabbitMQ,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
冪等性本身是數(shù)學(xué)上的概念,即使公式:f(x)=f(f(x)) 能夠成立的數(shù)學(xué)性質(zhì)。在開(kāi)發(fā)領(lǐng)域,則表示對(duì)于同一個(gè)系統(tǒng),使用相同的條件,一次請(qǐng)求和多次請(qǐng)求對(duì)系統(tǒng)資源的影響是一致的。
在分布式系統(tǒng)中冪等性尤為重要,因?yàn)榉植际较到y(tǒng)中,我們經(jīng)常會(huì)用到接口調(diào)用失敗進(jìn)而進(jìn)行重試這個(gè)功能,這樣就帶來(lái)了對(duì)一個(gè)接口可能會(huì)使用相同的條件進(jìn)行重復(fù)調(diào)用,在這樣的條件下,保證接口的冪等性就尤為重要了。
了解了問(wèn)題,那么解決方案就很好整了,常見(jiàn)的方案有:
MVCC 是多版本并發(fā)控制,這種方式就是在數(shù)據(jù)更新的時(shí)候需要去比較所持有的數(shù)據(jù)版本號(hào),版本號(hào)不一致的話,操作會(huì)失敗,這樣每個(gè) version 就只有一次執(zhí)行成功的機(jī)會(huì),一旦失敗了必須重新獲取。這種方式松哥以后可以抽空和大家細(xì)聊。
Token 則是目前使用比較廣的一種方式,核心思想就是每個(gè)操作都有一個(gè)唯一憑證 token,一旦執(zhí)行成功,對(duì)于重復(fù)的請(qǐng)求,總是返回同一個(gè)結(jié)果。
松哥這次在微人事的 RabbitMQ 消費(fèi)端實(shí)際上就是采用了 Token 這種方式。
大致的思路是這樣,首先將 RabbitMQ 的消息自動(dòng)確認(rèn)機(jī)制改為手動(dòng)確認(rèn),然后每當(dāng)有一條消息消費(fèi)成功了,就把該消息的唯一 ID 記錄在 Redis 上,然后每次收到消息時(shí),都先去 Redis 上查看是否有該消息的 ID,如果有,表示該消息已經(jīng)消費(fèi)過(guò)了,不再處理,否則再去處理。
上述就是小編為大家分享的Spring Boot 中怎么整合 RabbitMQ了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。