溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Spring Boot 中怎么整合 RabbitMQ

發(fā)布時(shí)間:2021-08-02 15:45:21 來(lái)源:億速云 閱讀:104 作者:Leah 欄目:大數(shù)據(jù)

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)Spring Boot 中怎么整合 RabbitMQ,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

 

1.簡(jiǎn)單說(shuō)說(shuō)冪等性

冪等性本身是數(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
  • Token 機(jī)制
  • 設(shè)計(jì)去重表
  • ...

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é)果。

 

2.微人事解決方案

松哥這次在微人事的 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è)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI