RabbitMQ簡介
專注于為中小企業(yè)提供成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)雨花臺免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了超過千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。RabbitMQ是一個在AMQP基礎(chǔ)上完整的,可復(fù)用的企業(yè)消息系統(tǒng)
MQ全稱為Message Queue, 消息隊(duì)列(MQ)是一種應(yīng)用程序?qū)?yīng)用程序的通信方法。應(yīng)用程序通過讀寫出入隊(duì)列的消息(針對應(yīng)用程序的數(shù)據(jù))來通信,而無需專用連接來鏈接它們。消息傳遞指的是程序之間通過在消息中發(fā)送數(shù)據(jù)進(jìn)行通信,而不是通過直接調(diào)用彼此來通信,直接調(diào)用通常是用于諸如遠(yuǎn)程過程調(diào)用的技術(shù)。排隊(duì)指的是應(yīng)用程序通過 隊(duì)列來通信。隊(duì)列的使用除去了接收和發(fā)送應(yīng)用程序同時(shí)執(zhí)行的要求。
AMQP就是一個協(xié)議,是一個高級抽象層消息通信協(xié)議。
雖然在同步消息通訊的世界里有很多公開標(biāo)準(zhǔn)(如 COBAR的 IIOP ,或者是 SOAP 等),但是在異步消息處理中卻不是這樣,只有大企業(yè)有一些商業(yè)實(shí)現(xiàn)(如微軟的 MSMQ ,IBM 的 Websphere MQ 等),因此,在 2006 年的 6 月,Cisco 、Redhat、iMatix 等聯(lián)合制定了 AMQP 的公開標(biāo)準(zhǔn)。也就是說AMQP是異步通訊的一個協(xié)議。
RabbitMQ使用場景
在項(xiàng)目中,將一些無需即時(shí)返回且耗時(shí)的操作提取出來,進(jìn)行了異步處理,而這種異步處理的方式大大的節(jié)省了服務(wù)器的請求響應(yīng)時(shí)間,從而提高了系統(tǒng)的吞吐量。不過大多數(shù)不僅僅是無需即時(shí)返回,甚至是執(zhí)行是否成功都無所謂。如果需要即時(shí)返回則可以使用Dubbo,Spring boot與Dubbo集成可以去看Spring boot 集成Dubbox
RabbitMQ依賴
RabbitMQ并不是直接一個簡單的jar包(Jar包只是提供一個基本的與RabbitMQ本身通訊的一些功能),和Dubbo相同,RabbitMQ也需要其他軟件來運(yùn)行,以下是RabbitMQ運(yùn)行所需要的軟件
1、Erlang
由于RabbitMQ軟件本身是基于Erlang開發(fā)的,所以想要運(yùn)行RabbitMQ必須要先按照Erlang
Erlang官網(wǎng)
Erlang下載地址
RabbitMQ
RabbitMQ才是實(shí)現(xiàn)消息隊(duì)列的核心
RabbitMQ官網(wǎng)
RabbitMQ下載
配置RabbitMQ
安裝完成后,需要完成一些配置才能使用RabbitMQ,可以直接用cmd到RabbitMQ的安裝目錄下的sbin目錄通過命令配置,也可以直接在開始菜單中直接找到RabbitMQ Command Prompt (sbin dir)運(yùn)行直接到達(dá)RabbitMQ的安裝目錄的sbin,為了方便,我們先啟用管理插件,執(zhí)行命令
rabbitmq-plugins.bat enable rabbitmq_management