一、RabbitMQ 的安裝
RabbitMQ 是基于 Erlang 語言編寫,因此,在安裝 RabbitMQ 之前需要先安裝 Erlang。
安裝 Erlang 和 RabbitMQ 需要依據(jù)二者的版本信息對照表 ,否則會出現(xiàn)版本信息不匹配的情況。
Erlang:opt 23.x
RabbitMQ:3.8.9
1.1 安裝 Erlang
通過源碼編譯安裝 Erlang,步驟如下:
(1) 首先,安裝 Erlang 所需要的依賴
# 下載 Erlan g源碼
sudo yum install -y gcc gcc-c++ glibc-devel make ncurses-devel openssl-devel autoconf java-1.8.0-openjdk-devel
(2) 然后,下載、解壓、編譯、安裝 Erlang
# 下載
wget http://erlang.org/download/otp_src_22.3.tar.gz
# 解壓
tar -zxvf otp_src_22.3.tar.gz
# 編譯
./otp_build autoconf
# 安裝
./configure && make && make install
(3) 最后,驗(yàn)證 Erlang
erl
1.2 安裝 RabbitMQ
通過 yum 的方式安裝 RabbitMQ,步驟如下:
(1) 首先,在官網(wǎng)獲取 RabbitMQ 的 yum 源
[bintray-rabbitmq-server]
name=bintray-rabbitmq-rpm
baseurl=https://dl.bintray.com/rabbitmq/rpm/rabbitmq-server/v3.8.x/el/7/
gpgcheck=0
repo_gpgcheck=0
enabled=1
(2) 然后,通過 yum 安裝 RabbitMQ
yum install rabbitmq -y
(3) 最后,啟動服務(wù)
service rabbitmq-server start
二、RabbitMQ 的配置文件
通過 yum 安裝的 RabbitMQ 開始是沒有配置文件的,如果需要配置 RabbitMQ,則首先需要找到 RabbitMQ 配置文件的存放位置,然后下載一個(gè) RabbitMQ 配置文件的模板置于配置文件目錄中。
2.1 添加配置文件
(1) 首先,找到 RabbitMQ 的默認(rèn)配置文件
find / -name rabbitmq-defaults
cat rabbitmq-defaults

可以看出 RabbitMQ 配置文件為 /etc/rabbitmq/rabbitmq-env.conf
(2) 然后,下載配置文件模板置于目錄 /etc/rabbitmq/,并重命名為 rabbitmq-env.conf
(3) 最后,修改完配置文件后,重復(fù) RabbitMQ 服務(wù)
三、Web GUI 管理插件
RabbitMQ 提供了 Web GUI 管理插件,啟動插件后,可以在網(wǎng)頁上對 RabbitMQ 進(jìn)行管理。
3.1 啟動 GUI 管理插件
rabbitmq-plugins enable rabbitmq_management
3.2 登錄管理界面
通過訪問 http://ip:15672/ 可以進(jìn)入管理頁面,默認(rèn)情況下,訪問 RabbitMQ 服務(wù)器的用戶名和密碼都是 guest,但是,在3.3.0 版本開始,默認(rèn)情況下,guest 賬號禁止訪問 localhost 之外的地址。因此,需要修改配置文件,允許用 guest 賬號來登錄管理界面。
# 默認(rèn)情況為 true,現(xiàn)在修改為 false
loopback_users.guest = false
3.3 管理后臺的使用
使用 guest 賬號登錄成功后,就會進(jìn)入后臺管理頁面。在后臺管理頁面,可以看到消息的統(tǒng)計(jì)、Connection信息、Channel信息、還可以添加Exchange、Queue 以及添加用戶。
(1) 添加 Exchange

- Name:設(shè)置交換器的名稱,用來標(biāo)識 Exchange, 同一個(gè) Virtual Host 中交換器的名稱不能重復(fù)
- Type:設(shè)置交換器的類型,常用的類型有:fanout、direct、topic
- Durability:設(shè)置交換器是否持久化,Durable-持久化,Transient-非持久化
- Auto delete:設(shè)置交換器是否自動刪除,Yes - 當(dāng)交換器與隊(duì)列的最后一個(gè)解綁時(shí),交換器將自動刪除
- Internal:設(shè)置交換器是否為內(nèi)部專用,Yes - 表示內(nèi)部專用,客戶端不能向交換器投遞消息
- Arguments:參數(shù)列表,這是 AMQP 協(xié)議留給 RabbitMQ 做擴(kuò)展用的
(2) 添加 Queue

- Name:設(shè)置隊(duì)列的名稱,用來標(biāo)識 隊(duì)列
- Type:設(shè)置隊(duì)列的類型,classic、quorum
- Durability:設(shè)置交換器是否持久化,Durable-持久化,Transient-非持久化
- Auto delete:設(shè)置交換器是否自動刪除,Yes - 當(dāng)交換器與隊(duì)列的最后一個(gè)解綁時(shí),交換器將自動刪除
- Arguments:隊(duì)列的參數(shù)
隊(duì)列的參數(shù):
- x-message-ttl:消息的過期時(shí)間,單位:毫秒;
- x-expires:隊(duì)列過期時(shí)間,隊(duì)列在多長時(shí)間未被訪問將被刪除,單位:毫秒;
- x-max-length:隊(duì)列最大長度,超過該最大值,則將從隊(duì)列頭部開始刪除消息;
- x-max-length-bytes:隊(duì)列消息內(nèi)容占用最大空間,受限于內(nèi)存大小,超過該閾值則從隊(duì)列頭部開始刪除消息;
- x-overflow:設(shè)置隊(duì)列溢出行為。這決定了當(dāng)達(dá)到隊(duì)列的最大長度時(shí)消息會發(fā)生什么。有效值是drop-head、reject-publish或reject-publish-dlx。仲裁隊(duì)列類型僅支持drop-head;
- x-dead-letter-exchange:死信交換器名稱,過期或被刪除(因隊(duì)列長度超長或因空間超出閾值)的消息可指定發(fā)送到該交換器中;
- x-dead-letter-routing-key:死信消息路由鍵,在消息發(fā)送到死信交換器時(shí)會使用該路由鍵,如果不設(shè)置,則使用消息的原來的路由鍵值
- x-single-active-consumer:表示隊(duì)列是否是單一活動消費(fèi)者,true時(shí),注冊的消費(fèi)組內(nèi)只有一個(gè)消費(fèi)者消費(fèi)消息,其他被忽略,false時(shí)消息循環(huán)分發(fā)給所有消費(fèi)者(默認(rèn)false)
- x-max-priority:隊(duì)列要支持的最大優(yōu)先級數(shù);如果未設(shè)置,隊(duì)列將不支持消息優(yōu)先級;
- x-queue-mode(Lazy mode):將隊(duì)列設(shè)置為延遲模式,在磁盤上保留盡可能多的消息,以減少RAM的使用;如果未設(shè)置,隊(duì)列將保留內(nèi)存緩存以盡可能快地傳遞消息;
- x-queue-master-locator:在集群模式下設(shè)置鏡像隊(duì)列的主節(jié)點(diǎn)信息。
(3) 添加用戶

用戶角色與權(quán)限控制:
- administrator:超級管理員,能夠登錄后臺,能夠查看所有信息,修改所有的 Exchange、Queue、Bindings 等策略
- monitoring:監(jiān)控者,能夠登錄后臺,能夠查看所有的信息,但是,只能修改屬于自己的 Exchange、Queue、Bindings 等策略
- policymaker:策略制定者,能夠登錄后臺,不能查看節(jié)點(diǎn)的信息(Overview),但是,能夠修改屬于自己的 Exchange、Queue、Bindings 等策略
- management:普通管理這,能夠登錄后臺,不能查看節(jié)點(diǎn)的信息(Overview),不能修改屬于自己的Exchange、Queue、Bindings 等策略,但是能夠查看
- None:無法登錄后臺