ActiveMQ從入門到精通(三)

這是ActiveMQ系列的最后一篇文章哺窄,主要是關(guān)于ActiveMQ集群般婆,這里采用的方式是:Zookeeper+LevelDB+ActiveMQ到腥。前面2篇博客地址如下:《ActiveMQ從入門到精通(一)》《ActiveMQ從入門到精通(二)》腺兴。

利用Zookeeper實(shí)現(xiàn)ActiveMQ的高可用

話不多說左电,先來看一張ActiveMQ官方提供的架構(gòu)圖:

Zookeeper + ActiveMQ

Master/Slave broker的信息要注冊到ZK

注意到只有Master對外提供了服務(wù),Slave是待機(jī)狀態(tài)页响。當(dāng)Master出現(xiàn)故障篓足,ZK內(nèi)部的選舉機(jī)制,會(huì)讓一個(gè)Slave升級(jí)成Master對外提供服務(wù)闰蚕。

關(guān)于ZK栈拖,以后博主會(huì)有專題進(jìn)行介紹,這里不做詳細(xì)講解没陡,只需要了解通過ZK的協(xié)調(diào)涩哟、選舉、容錯(cuò)機(jī)制等會(huì)實(shí)現(xiàn)ActiveMQ的高可用盼玄。

既然要做到高可用贴彼,那么ZK也得是高可用的,所以這里的搭建方案是這樣的:

搭建方案

第一步:JDK環(huán)境

jdk環(huán)境

保證這3臺(tái)機(jī)器都安裝了JDK埃儿,并配置了JAVA環(huán)境變量器仗。

第二步:配置Zookeeper

zk環(huán)境變量

為什么要配置ZK環(huán)境變量呢?很簡單童番,我想在命令行下直接使用ZK相關(guān)的命令精钮,而不是進(jìn)入到安裝ZK目錄下的bin,更不想用絕對路徑剃斧。


zoo.cfg

注意dataDir目錄的指定轨香;注意2181是外部訪問ZK的端口;

2888:3888是ZK集群內(nèi)部通信(比如ZK原子廣播消息)的端口幼东,注意server.X的定義臂容,這是將ZK集群中的實(shí)例進(jìn)行編號(hào)科雳,實(shí)際上需要在dataDir目錄中新建myid文件,并與之保持一致策橘。

myid文件

第三步:啟動(dòng)ZK

zkServer start

可以通過netstat命令查看2722進(jìn)程炸渡,發(fā)現(xiàn)ZK的端口是2181娜亿,這和zoo.cfg的配置是一致的丽已。讓3臺(tái)機(jī)器的ZK都啟動(dòng)起來。


zk status


第四步:ActiveMQ主從配置

注意了买决,由于我將在3臺(tái)物理機(jī)上搭建一臺(tái)Master沛婴,2臺(tái)Slave,因此我這邊不需要對端口配置文件進(jìn)行改動(dòng)督赤。比如WEB管控臺(tái)的jetty.xml嘁灯。


activemq.xml:brokerName

3臺(tái)機(jī)器應(yīng)該對外只有一個(gè)統(tǒng)一的名稱,就是這個(gè)brokerName躲舌。3臺(tái)機(jī)器都修改成一個(gè)名稱即可丑婿。

這里持久化,我將采用LevelDB没卸,因此需要修改持久化配置:

leveldb

注意bind地址羹奉,其實(shí)是ActiveMQ集群內(nèi)部通信的TCP端口,和ActiveMQ對外提供的消息端口(默認(rèn)61616)不要搞混了约计。

hostname即本機(jī)的主機(jī)名稱诀拭。

給出ZK集群的列表以及zkPath。zkPath下面其實(shí)存放著ActiveMQ的節(jié)點(diǎn)煤蚌,在后續(xù)你會(huì)看到耕挨。

啟動(dòng)3臺(tái)機(jī)器上的ActiveMQ,然后利用ZooInspector你可以看到:

121節(jié)點(diǎn)是Master

此時(shí)此刻尉桩,基于ZK的ActiveMQ的高可用方案就做好了筒占。那么JAVA端訪問ActiveMQ有什么變化么?其實(shí)就是在創(chuàng)建ConnectionFactory的時(shí)候給定的URL有變化:

failover:(tcp://192.168.99.121:61616,tcp://192.168.99.122:61616,tcp://192.168.99.123:61616)?Randomize=false

就是一個(gè)失敗轉(zhuǎn)移協(xié)議蜘犁!

上面只是做了一個(gè)ActiveMQ的高可用方案翰苫,那么ActiveMQ集群呢?其實(shí)所謂的ActiveMQ集群就是多個(gè)ActiveMQ高可用之間產(chǎn)生關(guān)聯(lián):

ActiveMQ集群

高可用的ActiveMQ-1,ActiveMQ-2,...,ActiveMQ-N就可以組建ActiveMQ集群

在配置上很簡單沽瘦,其實(shí)就是ActiveMQ-1要知道ActiveMQ-2的信息而已革骨,這里大家可以自行百度,不在演示了析恋。

整個(gè)ActiveMQ從入門到精通系列就結(jié)束了良哲,希望對大家有幫助!我們RocketMQ系列再見~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末助隧,一起剝皮案震驚了整個(gè)濱河市筑凫,隨后出現(xiàn)的幾起案子滑沧,更是在濱河造成了極大的恐慌,老刑警劉巖巍实,帶你破解...
    沈念sama閱讀 212,454評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件滓技,死亡現(xiàn)場離奇詭異,居然都是意外死亡棚潦,警方通過查閱死者的電腦和手機(jī)令漂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來丸边,“玉大人叠必,你說我怎么就攤上這事∶媒眩” “怎么了纬朝?”我有些...
    開封第一講書人閱讀 157,921評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長骄呼。 經(jīng)常有香客問我共苛,道長,這世上最難降的妖魔是什么蜓萄? 我笑而不...
    開封第一講書人閱讀 56,648評(píng)論 1 284
  • 正文 為了忘掉前任隅茎,我火速辦了婚禮,結(jié)果婚禮上绕德,老公的妹妹穿的比我還像新娘患膛。我一直安慰自己,他們只是感情好耻蛇,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,770評(píng)論 6 386
  • 文/花漫 我一把揭開白布踪蹬。 她就那樣靜靜地躺著,像睡著了一般臣咖。 火紅的嫁衣襯著肌膚如雪跃捣。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,950評(píng)論 1 291
  • 那天夺蛇,我揣著相機(jī)與錄音疚漆,去河邊找鬼。 笑死刁赦,一個(gè)胖子當(dāng)著我的面吹牛娶聘,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播甚脉,決...
    沈念sama閱讀 39,090評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼丸升,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了牺氨?” 一聲冷哼從身側(cè)響起狡耻,我...
    開封第一講書人閱讀 37,817評(píng)論 0 268
  • 序言:老撾萬榮一對情侶失蹤墩剖,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后夷狰,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體岭皂,經(jīng)...
    沈念sama閱讀 44,275評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,592評(píng)論 2 327
  • 正文 我和宋清朗相戀三年沼头,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了爷绘。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,724評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡瘫证,死狀恐怖揉阎,靈堂內(nèi)的尸體忽然破棺而出庄撮,到底是詐尸還是另有隱情背捌,我是刑警寧澤,帶...
    沈念sama閱讀 34,409評(píng)論 4 333
  • 正文 年R本政府宣布洞斯,位于F島的核電站毡庆,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏烙如。R本人自食惡果不足惜么抗,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,052評(píng)論 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望亚铁。 院中可真熱鬧蝇刀,春花似錦、人聲如沸徘溢。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽然爆。三九已至站粟,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間曾雕,已是汗流浹背奴烙。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評(píng)論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留剖张,地道東北人切诀。 一個(gè)月前我還...
    沈念sama閱讀 46,503評(píng)論 2 361
  • 正文 我出身青樓,卻偏偏與公主長得像搔弄,于是被迫代替她去往敵國和親幅虑。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,627評(píng)論 2 350

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

  • 一肯污、ActiveMQ集群的簡單介紹 從 ActiveMQ 5.9 開始,ActiveMQ 的集群實(shí)現(xiàn)方式取消了傳統(tǒng)...
    會(huì)跳舞的機(jī)器人閱讀 3,588評(píng)論 0 18
  • 1 Zookeeper概述# ZooKeeper是一個(gè)為分布式應(yīng)用所設(shè)計(jì)的分布的翘单、開源的協(xié)調(diào)服務(wù)吨枉,它主要是用來解決...
    七寸知架構(gòu)閱讀 7,343評(píng)論 0 101
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)哄芜,斷路器貌亭,智...
    卡卡羅2017閱讀 134,637評(píng)論 18 139
  • ZooKeeper介紹 Zookeeper 分布式服務(wù)框架是 Apache Hadoop 的一個(gè)子項(xiàng)目,它主要是用...
    Coselding閱讀 11,384評(píng)論 1 37
  • 人生是海洋认臊,希望是舵手的羅盤圃庭,使人們在暴風(fēng)雨中不致迷失方向。 —— 狄德羅 1. 前言 ??ActiveMQ M...
    guqj閱讀 3,534評(píng)論 0 0