RabbitMQ:消息應答與消息持久化

9824247-dbd6b84206381f8e.jpg

在正式的生產(chǎn)環(huán)境中皂冰,我們不想丟失任何任務痊夭,如果有一個消費者掛掉了,那么我們應該將分發(fā)給它的任務交付給另一個消費者去處理。 為了確保消息不會丟失过咬,RabbitMQ支持消息應答。消費者發(fā)送一個消息應答制妄,告訴RabbitMQ這個消息已經(jīng)接收并且處理完畢了掸绞。RabbitMQ可以刪除它了。
那么如何設置RabbitMQ為手動應答模式呢耕捞?

1衔掸、Message acknowledgment(消息應答)

 boolean autoAck = false;  
 channel.basicConsume(QUEUE_NAME, autoAck, consumer);   
  • boolean autoAck = true;(自動確認模式)一旦RabbitMQ將消息分發(fā)給了消費者,就會從內(nèi)存中刪除俺抽。在這種情況下敞映,如果殺死正在執(zhí)行任務的消費者,會丟失正在處理的消息磷斧,也會丟失已經(jīng)分發(fā)給這個消費者但尚未處理的消息振愿。
  • boolean autoAck = false; (手動確認模式) 我們不想丟失任何任務,如果有一個消費者掛掉了弛饭,那么我們應該將分發(fā)給它的任務交付給另一個消費者去處理冕末。 為了確保消息不會丟失,RabbitMQ支持消息應答侣颂。消費者發(fā)送一個消息應答档桃,告訴RabbitMQ這個消息已經(jīng)接收并且處理完畢了。RabbitMQ可以刪除它了憔晒。
  • 消息應答是默認打開的藻肄。也就是boolean autoAck =false;

2、Message durability(消息持久化)

我們已經(jīng)了解了如何確保即使消費者死亡拒担,任務也不會丟失嘹屯。但是如果RabbitMQ服務器停止,我們的任務仍將失去澎蛛!當RabbitMQ退出或者崩潰抚垄,將會丟失隊列和消息。除非你不要隊列和消息谋逻。兩件事兒必須保證消息不被丟失:我們必須把“隊列”和“消息”設為持久化呆馁。

boolean durable = true;  
channel.queueDeclare("hrabbit_queue_work", durable, false, false, null); 

這里有一點需要注意的問題,我們直接把durable的false改成true就可以了嗎毁兆?因為我現(xiàn)在運行的程序中已經(jīng)存在了hrabbit_queue_work這個隊列浙滤,當我再次執(zhí)行的時候,會拋出如下的異常

channel error; protocol method: #method<channel.close>(reply-code=406, reply-text=PRECONDITION_FAILED - inequivalent arg 'durable' for queue 'hrabbit_queue_work'

盡管這行代碼是正確的气堕,他不會運行成功纺腊。因為我們已經(jīng)定義了一個名叫hrabbit_queue_work的未持久化的隊列畔咧。RabbitMQ不允許使用不同的參數(shù)設定重新定義已經(jīng)存在的隊列,并且會返回一個錯誤揖膜。 一個快速的解決方案——就是聲明一個不同名字的隊列誓沸,比如task_queue∫妓冢或者我們登錄控制臺將隊列刪除就可以了拜隧。

系列文章:

RabbitMQ:RabbitMQ-理論基礎
RabbitMQ:快速入門hello word
RabbitMQ:RabbitMQ:work queues 工作隊列(Round-robin/Fair dispatch)
RabbitMQ:發(fā)布/訂閱 Publish/Subscribe
RabbitMQ:路由Routing
RabbitMQ:Topic類型的exchange
RabbitMQ:RabbitMQ之消息確認機制(事務+Confirm)
RabbitMQ:spring整合RabbitMQ

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市趁仙,隨后出現(xiàn)的幾起案子洪添,更是在濱河造成了極大的恐慌,老刑警劉巖雀费,帶你破解...
    沈念sama閱讀 222,627評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件干奢,死亡現(xiàn)場離奇詭異,居然都是意外死亡盏袄,警方通過查閱死者的電腦和手機忿峻,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來貌矿,“玉大人炭菌,你說我怎么就攤上這事」渎” “怎么了黑低?”我有些...
    開封第一講書人閱讀 169,346評論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長酌毡。 經(jīng)常有香客問我克握,道長,這世上最難降的妖魔是什么枷踏? 我笑而不...
    開封第一講書人閱讀 60,097評論 1 300
  • 正文 為了忘掉前任菩暗,我火速辦了婚禮,結果婚禮上旭蠕,老公的妹妹穿的比我還像新娘停团。我一直安慰自己,他們只是感情好掏熬,可當我...
    茶點故事閱讀 69,100評論 6 398
  • 文/花漫 我一把揭開白布佑稠。 她就那樣靜靜地躺著,像睡著了一般旗芬。 火紅的嫁衣襯著肌膚如雪舌胶。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,696評論 1 312
  • 那天疮丛,我揣著相機與錄音幔嫂,去河邊找鬼辆它。 笑死,一個胖子當著我的面吹牛履恩,可吹牛的內(nèi)容都是我干的锰茉。 我是一名探鬼主播,決...
    沈念sama閱讀 41,165評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼似袁,長吁一口氣:“原來是場噩夢啊……” “哼洞辣!你這毒婦竟也來了?” 一聲冷哼從身側響起昙衅,我...
    開封第一講書人閱讀 40,108評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎定鸟,沒想到半個月后而涉,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,646評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡联予,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,709評論 3 342
  • 正文 我和宋清朗相戀三年啼县,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片沸久。...
    茶點故事閱讀 40,861評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡季眷,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出卷胯,到底是詐尸還是另有隱情子刮,我是刑警寧澤,帶...
    沈念sama閱讀 36,527評論 5 351
  • 正文 年R本政府宣布窑睁,位于F島的核電站挺峡,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏担钮。R本人自食惡果不足惜橱赠,卻給世界環(huán)境...
    茶點故事閱讀 42,196評論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望箫津。 院中可真熱鬧狭姨,春花似錦、人聲如沸苏遥。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,698評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽暖眼。三九已至惕耕,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間诫肠,已是汗流浹背司澎。 一陣腳步聲響...
    開封第一講書人閱讀 33,804評論 1 274
  • 我被黑心中介騙來泰國打工欺缘, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人挤安。 一個月前我還...
    沈念sama閱讀 49,287評論 3 379
  • 正文 我出身青樓谚殊,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蛤铜。 傳聞我的和親對象是個殘疾皇子嫩絮,可洞房花燭夜當晚...
    茶點故事閱讀 45,860評論 2 361

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

  • 來源 RabbitMQ是用Erlang實現(xiàn)的一個高并發(fā)高可靠AMQP消息隊列服務器。支持消息的持久化围肥、事務剿干、擁塞控...
    jiangmo閱讀 10,369評論 2 34
  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn)穆刻,斷路器置尔,智...
    卡卡羅2017閱讀 134,716評論 18 139
  • 應用場景 異步處理 場景說明:用戶注冊后,需要發(fā)注冊郵件和注冊短信氢伟,傳統(tǒng)的做法有兩種: 1.串行的方式 2.并行的...
    lijun_m閱讀 1,834評論 0 3
  • http://liuxing.info/2017/06/30/Spring%20AMQP%E4%B8%AD%E6%...
    sherlock_6981閱讀 15,943評論 2 11
  • 文/莘子 圖/網(wǎng)絡 2017.08.08 1 小婷是個很活潑的姑娘朵锣,有一個很疼她的男朋友谬盐,平時她抱怨她男朋友怎樣時...
    莘子月閱讀 770評論 3 2