rabbitmq network partition配置

參考

Network partition detected
RabbitMQ 之 Clustering 和 Network Partition(翻譯)
rabbitmq對network partition的處理
how did we recover from rabbitmq cluster network partition
RabbitMQ入門教程10--partitions
rabbitmq之partitions

0.描述

rabbitmq沒有很好的分區(qū)容錯性拘央,因此篓跛,如果需要在廣域網(wǎng)里使用rabbitmq集群戚丸,建議使用federation或者shovel進(jìn)行替代。那么即使rabbitmq集群運(yùn)行在局域網(wǎng)內(nèi)也不能完全避免網(wǎng)絡(luò)分區(qū)現(xiàn)象(network partition),例如腕唧,當(dāng)路由器或者交換機(jī)出現(xiàn)問題,或者網(wǎng)口down掉時,都可能發(fā)生網(wǎng)絡(luò)分區(qū)琳拭。

當(dāng)發(fā)生網(wǎng)絡(luò)分區(qū)時,不同分區(qū)里的節(jié)點(diǎn)都認(rèn)為對方down掉描验,對exchange白嘁,queue,binding的操作都僅針對本分區(qū)有效膘流;存儲在mnesia的元數(shù)據(jù)(exchange相關(guān)屬性絮缅,queue相關(guān)屬性等)不會在集群間進(jìn)行數(shù)據(jù)同步;另外呼股,對于鏡像隊列盟蚣,在各自的分區(qū)里都會存在一個master進(jìn)程處理隊列的相關(guān)操作。更重要的是卖怜,當(dāng)網(wǎng)絡(luò)分區(qū)恢復(fù)后屎开,這些現(xiàn)象依舊是存在的!

1.現(xiàn)象

#vi /var/log/rabbitmq/rabbit\@mq236.log
=ERROR REPORT==== 30-Mar-2017::00:19:58 ===
Mnesia(rabbit@mq237): ** ERROR ** mnesia_event got {inconsistent_database, running_partitioned_network, rabbit@mq236}

#正常情況
[root@mq236 rabbitmq]# rabbitmqctl cluster_status
Cluster status of node rabbit@mq236 ...
[{nodes,[{disc,[rabbit@mq236,rabbit@mq237,rabbit@mq238]}]},
 {running_nodes,[rabbit@mq237,rabbit@mq238,rabbit@mq236]},
 {cluster_name,<<"rabbit@mq237">>},
 {partitions,[]},
 {alarms,[{rabbit@mq237,[]},{rabbit@mq238,[]},{rabbit@mq236,[]}]}]

 #network partition異常情況
[root@mq236 rabbitmq]# rabbitmqctl cluster_status
Cluster status of node rabbit@mq236 ...
[{nodes,[{disc,[rabbit@mq236,rabbit@mq237,rabbit@mq238]}]},
 {running_nodes,[rabbit@mq237,rabbit@mq236]},
 {cluster_name,<<"rabbit@mq237">>},
 {partitions,[{rabbit@mq237,[rabbit@mq238]},{rabbit@mq236,[rabbit@mq238]}]},
 {alarms,[{rabbit@mq237,[]},{rabbit@mq236,[]}]}]

2.配置項

  • ignore
    默認(rèn)類型,不處理奄抽。
    要求你所在的網(wǎng)絡(luò)環(huán)境非嘲剑可靠。例如逞度,你的所有 node 都在同一個機(jī)架上额划,通過交換機(jī)互聯(lián),并且該交換機(jī)還是與外界通信的必經(jīng)之路档泽。

  • pause_minority
    rabbitmq節(jié)點(diǎn)感知集群中其他節(jié)點(diǎn)down掉時俊戳,會判斷自己在集群中處于多數(shù)派還是少數(shù)派,也就是判斷與自己形成集群的節(jié)點(diǎn)個數(shù)在整個集群中的比例是否超過一半馆匿。如果是多數(shù)派抑胎,則正常工作,如果是少數(shù)派渐北,則會停止rabbit應(yīng)用并不斷檢測直到自己成為多數(shù)派的一員后再次啟動rabbit應(yīng)用阿逃。注意:這種處理方式集群通常由奇數(shù)個節(jié)點(diǎn)組成。在CAP中赃蛛,優(yōu)先保證了CP恃锉。
    注意:pause_minority適用情形有限制,如3個節(jié)點(diǎn)集群呕臂,每次只down1個時破托,此模式適用。但如果網(wǎng)絡(luò)都出問題歧蒋,3節(jié)點(diǎn)會獨(dú)立形成3個集群炼团。

  • autoheal
    你的網(wǎng)絡(luò)環(huán)境可能是不可靠的。你會更加關(guān)心服務(wù)的可持續(xù)性疏尿,而非數(shù)據(jù)完整性瘟芝。你可以構(gòu)建一個包含2個node的集群。
    當(dāng)網(wǎng)絡(luò)分區(qū)恢復(fù)后褥琐,rabbitmq各分區(qū)彼此進(jìn)行協(xié)商锌俱,分區(qū)中客戶端連接數(shù)最多的為勝者,其余的全部會進(jìn)行重啟敌呈,恢復(fù)到同步狀態(tài)鲫尊。

3.配置

在/etc/rabbitmq下新建rabbitmq.conf雨饺,加入:

[
 {rabbit,
  [{tcp_listeners,[5672]},
   {cluster_partition_handling, pause_minority}
]}
].

4.錯誤處理

  1. 選擇一個想要保留的集群
  2. 重啟其它分區(qū)內(nèi)所有節(jié)點(diǎn)珊豹,當(dāng)它們重新加入集群時威创,將從信任的分區(qū)中恢復(fù)狀態(tài)。其他分區(qū)上已發(fā)生的操作將丟失析显。
  3. 重啟信任分區(qū)內(nèi)的所有節(jié)點(diǎn)以消除警告鲫咽。

5.問題

1.設(shè)置類型為pause_minority后,一段時間后3節(jié)點(diǎn)集群變成3個獨(dú)立集群;嘗試配置為autoheal分尸,一段時間后依然出現(xiàn)變?yōu)?個獨(dú)立集群锦聊;
查閱日志(/var/log/rabbitmq/)發(fā)現(xiàn),經(jīng)常出現(xiàn)heartbeat報錯:

=ERROR REPORT==== 30-Mar-2017::17:52:02 ===
closing AMQP connection <0.9426.203> (10.101.232.241:48740 -> 10.102.43.238:5672):
missed heartbeats from client, timeout: 60s

因此嘗試將heartbeat從60s設(shè)置為200s箩绍,觀察一段時間后未出現(xiàn)錯誤孔庭。

[
 {rabbit,
  [{tcp_listeners,[5672]},
   {heartbeat,200},
   {cluster_partition_handling,autoheal}
 ]}
].
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市材蛛,隨后出現(xiàn)的幾起案子圆到,更是在濱河造成了極大的恐慌,老刑警劉巖卑吭,帶你破解...
    沈念sama閱讀 222,104評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件芽淡,死亡現(xiàn)場離奇詭異,居然都是意外死亡陨簇,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評論 3 399
  • 文/潘曉璐 我一進(jìn)店門迹淌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來河绽,“玉大人,你說我怎么就攤上這事唉窃“沂危” “怎么了?”我有些...
    開封第一講書人閱讀 168,697評論 0 360
  • 文/不壞的土叔 我叫張陵纹份,是天一觀的道長苟跪。 經(jīng)常有香客問我,道長蔓涧,這世上最難降的妖魔是什么件已? 我笑而不...
    開封第一講書人閱讀 59,836評論 1 298
  • 正文 為了忘掉前任,我火速辦了婚禮元暴,結(jié)果婚禮上篷扩,老公的妹妹穿的比我還像新娘。我一直安慰自己茉盏,他們只是感情好鉴未,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,851評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著鸠姨,像睡著了一般铜秆。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上讶迁,一...
    開封第一講書人閱讀 52,441評論 1 310
  • 那天连茧,我揣著相機(jī)與錄音,去河邊找鬼。 笑死梅屉,一個胖子當(dāng)著我的面吹牛值纱,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播坯汤,決...
    沈念sama閱讀 40,992評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼虐唠,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了惰聂?” 一聲冷哼從身側(cè)響起疆偿,我...
    開封第一講書人閱讀 39,899評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎搓幌,沒想到半個月后杆故,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,457評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡溉愁,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,529評論 3 341
  • 正文 我和宋清朗相戀三年处铛,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片拐揭。...
    茶點(diǎn)故事閱讀 40,664評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡撤蟆,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出堂污,到底是詐尸還是另有隱情家肯,我是刑警寧澤,帶...
    沈念sama閱讀 36,346評論 5 350
  • 正文 年R本政府宣布盟猖,位于F島的核電站讨衣,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏式镐。R本人自食惡果不足惜反镇,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,025評論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望娘汞。 院中可真熱鬧愿险,春花似錦、人聲如沸价说。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽鳖目。三九已至扮叨,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間领迈,已是汗流浹背彻磁。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評論 1 272
  • 我被黑心中介騙來泰國打工碍沐, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人衷蜓。 一個月前我還...
    沈念sama閱讀 49,081評論 3 377
  • 正文 我出身青樓累提,卻偏偏與公主長得像,于是被迫代替她去往敵國和親磁浇。 傳聞我的和親對象是個殘疾皇子斋陪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,675評論 2 359

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

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)置吓,斷路器无虚,智...
    卡卡羅2017閱讀 134,704評論 18 139
  • 由于之前做的項目中需要在多個節(jié)點(diǎn)之間可靠地通信,所以廢棄了之前使用的Redis pub/sub(因為集群有單點(diǎn)問題...
    iEpacJ閱讀 1,965評論 0 1
  • 本文轉(zhuǎn)載自http://dataunion.org/?p=9307 背景介紹Kafka簡介Kafka是一種分布式的...
    Bottle丶Fish閱讀 5,475評論 0 34
  • 本文檔翻譯自 http://redis.io/topics/cluster-tutorial 衍锚。 本文檔是 Red...
    會跳舞的機(jī)器人閱讀 66,935評論 2 21
  • 聽說 在答題吧簽約 就有好禮相送 我趕緊約了起來 你也來約吧 http://mp.weixin.qq.com/s/...
    玉在櫝中求善價閱讀 227評論 0 0