消息隊列中間件以及初識ActiveMQ

消息中間件通也被稱為消息隊列服務器,是當今分布式應用架構(gòu)中經(jīng)常采用的技術(shù)遣鼓。

在系統(tǒng)軟件中,操作系統(tǒng)重贺、數(shù)據(jù)庫骑祟、中間件三駕馬車回懦,對于專業(yè)人士來說,中間件也是最神秘的次企。中間件是一個專業(yè)化非常強的細分產(chǎn)業(yè)怯晕,中間件的技術(shù)門檻較高。但是從 2008 年開始中間件得到了蓬勃發(fā)展缸棵,開發(fā)者對中間件這個詞不再陌生舟茶,周圍被各種中間件圍繞。

其中消息隊列是開發(fā)中經(jīng)常用到的一種中間件技術(shù)堵第。

什么是消息中間件吧凉?

消息中間件是利用高效可靠的消息傳遞機制進行平臺無關(guān)的數(shù)據(jù)通信來達到分布式系統(tǒng)的集成目的,通過提供消息傳遞和消息排隊模型踏志,可以在分布式架構(gòu)下擴展進程之間的通信阀捅。對于消息中間件,常見的角色就是Producer(生產(chǎn)者)针余、Consumer(消費者) 饲鄙、broker(消息中間件實例)。

消息隊列發(fā)展史

世界上第一個現(xiàn)代消息隊列軟件 The Information Bus(TIB)圆雁,采用發(fā)布訂閱的模式解決不同程序直接的通信需求忍级, TIB 的發(fā)展引起了IBM的注意,于是IBM開發(fā)了自己的消息隊列軟件“IBM WebSphere MQ”伪朽,后來微軟發(fā)布了自己的(MSMQ)颤练。

隨著IT信息時代的發(fā)展,程序之間互聯(lián)互通的需求越來越強烈驱负,但是各大IT廠商們還是牢牢建立著各種技術(shù)壁壘嗦玖,保證自己的商業(yè)利益,消息中間件依舊是各大型企業(yè)能夠用的起的東西跃脊。

各大廠商直接的協(xié)議不通宇挫,導致了開發(fā)成本的增加,一個開發(fā)人員既要懂IBM的酪术,又要懂微軟的器瘪,對開發(fā)人員來說也充滿了壓力,2001年sun發(fā)布了 JMS ( Java Message Service)技術(shù)绘雁,試圖在各大廠商的基礎(chǔ)上再包裝一層統(tǒng)一的 Java 規(guī)范橡疼, Java 程序只需要針對 JMS API 編程就可以了,不需要關(guān)注使用了什么樣的消息中間件庐舟,但是 JMS 僅僅適用于 Java 欣除。

2004年 AMQP (高級消息隊列協(xié)議)誕生了,真正促進了消息隊列的繁榮發(fā)展挪略,任何人都可以針對 AMQP 的標準進行編碼历帚,并和實現(xiàn)了 AMQP 的中間件供應商進行通信滔岳。

加上互聯(lián)網(wǎng)分布式應用的迅猛發(fā)展,使得消息中間件一飛沖天挽牢,開源消息中間件層出不窮谱煤,常見比較流行的有 ActiveMQ、RabbitMQ禽拔、Kafak刘离、阿里的 RocketMQ 等,在互聯(lián)網(wǎng)應用中消息隊列中間件基本上成為標配睹栖。

消息隊列的應用場景

在高并發(fā)環(huán)境下硫惕,我們會利用消息隊列進行異步,解耦磨淌,流量削峰疲憋。

異步處理+系統(tǒng)解耦

拿“用戶注冊”這個業(yè)務來說,除了要把用戶信息保存到數(shù)據(jù)庫之外梁只,注冊成功后缚柳,我們還需要給用戶短信發(fā)送注冊結(jié)果,通知積分系統(tǒng)為用戶贈送積分等等搪锣。

假設這3個操作秋忙,每個操作需要1秒鐘,那么整個注冊過程就需要3秒鐘才能響應給用戶构舟。其實對注冊服務來說灰追,最重要的就是信息入庫,后面的短信提醒和贈送積分可以采用異步執(zhí)行狗超,提高系統(tǒng)的響應能力弹澎。

用戶注冊

實行異步化處理,可以采用多線程的方式實現(xiàn)努咐,但是對于消息的持久化苦蒿,消息的重發(fā)來說,多線程的方式不能很好的支持渗稍,因此我們可以借助一些開源中間件來解決佩迟。

注冊服務異步處理

通過異步處理,給用戶響應的時間可以提高到1秒竿屹,同時短信提醒和贈送積分可以并行操作报强,提升了系統(tǒng)的處理效率,提高了系統(tǒng)性能拱燃。

把信息入庫秉溉,短信提醒,贈送積分等等操作寫到不同的系統(tǒng)里,做成不同的服務坚嗜,使系統(tǒng)之間做到解耦夯膀,不必把這些操作都放到注冊服務里诗充,同時可以做到系統(tǒng)解耦苍蔬。

流量削峰

在高并發(fā)環(huán)境下,前端請求流量會非常大蝴蜓,通過消息隊列的方式可以很好的緩解高流量的問題碟绑,比如秒殺業(yè)務。前端請求先寫入消息隊列茎匠,然后給用戶返回格仲,當消息隊列超過指定的長度,直接丟棄诵冒;秒殺服務負責處理核心業(yè)務凯肋,接收消息隊列的消息進行秒殺處理,以達到流量的削峰汽馋。

流量削峰

ActiveMQ 簡介以及下載安裝

Apache ActiveMQ 是最流行的開源侮东,多協(xié)議,基于Java JMS 規(guī)范的消息服務器豹芯。ActiveMQ 主要應用在分布式系統(tǒng)架構(gòu)中悄雅,構(gòu)建高可用、 高性能铁蹈、可伸縮的面向消息服務的系統(tǒng)宽闲,它支持行業(yè)標準協(xié)議,使用 AMQP 協(xié)議集成多平臺應用程序握牧,使用 STOMP 通過 websockets 在 Web 應用程序之間交換消息容诬,ActiveMQ 提供強大的功能以支持任何消息的傳遞。

由于 ActiveMQ 是一個純 Java 程序沿腰,因此只需要操作系統(tǒng)支持 Java 虛擬機览徒,ActiveMQ 便可執(zhí)行。

1矫俺、完全支持 JMS 1.1 和 J2EE 1.4規(guī)范吱殉;2、Spring 支持厘托,以便ActiveMQ可以輕松嵌入到Spring應用程序中友雳,并使用Spring的XML配置機制進行配置

ActiveMQ 官網(wǎng)地址

ActiveMQ 的安裝

1、下載地址:Download Archives

下載地址

選擇你想安裝的版本進行下載

選擇安裝包

Linux系統(tǒng)選擇tar.gz版本铅匹,windows系統(tǒng)選擇bin.zip版本進行下載押赊。

2、把下載好的壓縮包拷貝到服務器上,進行解壓

解壓命令:tar -zxvf apache-activemq-5.15.0-bin.tar.gz

解壓后流礁,activemq的文件目錄結(jié)構(gòu)為如下:

目錄名稱 目錄說明
data log文件和kahadb文件
lib 一些jia包
bin 啟動腳本等shell目錄
conf activemq.xml等配置文件
activemq-all-5.15.0.jar 開發(fā)所需jar包
docs 使用文檔
examples 使用樣例
webapps 監(jiān)控服務

3涕俗、啟動運行,到bin目錄下執(zhí)行命令進行啟動activeMQ服務

啟動命令:sh activemq start

4神帅、檢查是否啟動

ActiveMQ 默認采用 61616 端口提供消息服務再姑,使用 8161 端口提供管理監(jiān)控服務。

執(zhí)行以下命令可以檢查是否成功啟動 ActiveMQ 服務:

netstat an|grep 61616

或者執(zhí)行以下命令檢查是否成功啟動 ActiveMQ 服務:

ps -ef|grep activemq

可以通過啟動日志查看找御,是否有異常:

tail -fn500 ../data/activemq.log

5元镀、通過 http://你的ip地址:8161 訪問 activeMQ 管理頁面,如下:

activeMQ 管理頁面

默認帳號/密碼:admin/admin

服務已經(jīng)啟動

這樣霎桅,說明ActiveMQ 服務已經(jīng)啟動栖疑。

6、關(guān)閉 ActiveMQ 服務: sh activemq stop

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末滔驶,一起剝皮案震驚了整個濱河市遇革,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌揭糕,老刑警劉巖萝快,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異插佛,居然都是意外死亡杠巡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進店門雇寇,熙熙樓的掌柜王于貴愁眉苦臉地迎上來氢拥,“玉大人,你說我怎么就攤上這事锨侯∧酆#” “怎么了?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵囚痴,是天一觀的道長叁怪。 經(jīng)常有香客問我,道長深滚,這世上最難降的妖魔是什么奕谭? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮痴荐,結(jié)果婚禮上血柳,老公的妹妹穿的比我還像新娘。我一直安慰自己生兆,他們只是感情好难捌,可當我...
    茶點故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般根吁。 火紅的嫁衣襯著肌膚如雪员淫。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天击敌,我揣著相機與錄音介返,去河邊找鬼。 笑死愚争,一個胖子當著我的面吹牛映皆,可吹牛的內(nèi)容都是我干的挤聘。 我是一名探鬼主播轰枝,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼组去!你這毒婦竟也來了鞍陨?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤从隆,失蹤者是張志新(化名)和其女友劉穎诚撵,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體键闺,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡寿烟,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了辛燥。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片筛武。...
    茶點故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖挎塌,靈堂內(nèi)的尸體忽然破棺而出徘六,到底是詐尸還是另有隱情,我是刑警寧澤榴都,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布待锈,位于F島的核電站,受9級特大地震影響嘴高,放射性物質(zhì)發(fā)生泄漏竿音。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一拴驮、第九天 我趴在偏房一處隱蔽的房頂上張望春瞬。 院中可真熱鬧,春花似錦莹汤、人聲如沸快鱼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽抹竹。三九已至线罕,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間窃判,已是汗流浹背钞楼。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留袄琳,地道東北人询件。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓,卻偏偏與公主長得像唆樊,于是被迫代替她去往敵國和親宛琅。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,722評論 2 345

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