一、RabbitMQ 的安装
RabbitMQ 是基于 Erlang 语言编写,因此,在安装 RabbitMQ 之前需要先安装 Erlang。
安装 Erlang 和 RabbitMQ 需要依据二者的版本信息对照表 ,否则会出现版本信息不匹配的情况。
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) 最后,验证 Erlang
erl
1.2 安装 RabbitMQ
通过 yum
的方式安装 RabbitMQ,步骤如下:
(1) 首先,在官网获取 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) 最后,启动服务
service rabbitmq-server start
二、RabbitMQ 的配置文件
通过 yum 安装的 RabbitMQ 开始是没有配置文件的,如果需要配置 RabbitMQ,则首先需要找到 RabbitMQ 配置文件的存放位置,然后下载一个 RabbitMQ 配置文件的模板置于配置文件目录中。
2.1 添加配置文件
(1) 首先,找到 RabbitMQ 的默认配置文件
find / -name rabbitmq-defaults
cat rabbitmq-defaults
可以看出 RabbitMQ 配置文件为 /etc/rabbitmq/rabbitmq-env.conf
(2) 然后,下载配置文件模板置于目录 /etc/rabbitmq/
,并重命名为 rabbitmq-env.conf
(3) 最后,修改完配置文件后,重复 RabbitMQ 服务
三、Web GUI 管理插件
RabbitMQ 提供了 Web GUI 管理插件,启动插件后,可以在网页上对 RabbitMQ 进行管理。
3.1 启动 GUI 管理插件
rabbitmq-plugins enable rabbitmq_management
3.2 登录管理界面
通过访问 http://ip:15672/
可以进入管理页面,默认情况下,访问 RabbitMQ 服务器的用户名和密码都是 guest,但是,在3.3.0 版本开始,默认情况下,guest 账号禁止访问 localhost 之外的地址。因此,需要修改配置文件,允许用 guest 账号来登录管理界面。
# 默认情况为 true,现在修改为 false
loopback_users.guest = false
3.3 管理后台的使用
使用 guest 账号登录成功后,就会进入后台管理页面。在后台管理页面,可以看到消息的统计、Connection信息、Channel信息、还可以添加Exchange、Queue 以及添加用户。
(1) 添加 Exchange
- Name:设置交换器的名称,用来标识 Exchange, 同一个 Virtual Host 中交换器的名称不能重复
- Type:设置交换器的类型,常用的类型有:fanout、direct、topic
- Durability:设置交换器是否持久化,Durable-持久化,Transient-非持久化
- Auto delete:设置交换器是否自动删除,Yes - 当交换器与队列的最后一个解绑时,交换器将自动删除
- Internal:设置交换器是否为内部专用,Yes - 表示内部专用,客户端不能向交换器投递消息
- Arguments:参数列表,这是 AMQP 协议留给 RabbitMQ 做扩展用的
(2) 添加 Queue
- Name:设置队列的名称,用来标识 队列
- Type:设置队列的类型,classic、quorum
- Durability:设置交换器是否持久化,Durable-持久化,Transient-非持久化
- Auto delete:设置交换器是否自动删除,Yes - 当交换器与队列的最后一个解绑时,交换器将自动删除
- Arguments:队列的参数
队列的参数:
- x-message-ttl:消息的过期时间,单位:毫秒;
- x-expires:队列过期时间,队列在多长时间未被访问将被删除,单位:毫秒;
- x-max-length:队列最大长度,超过该最大值,则将从队列头部开始删除消息;
- x-max-length-bytes:队列消息内容占用最大空间,受限于内存大小,超过该阈值则从队列头部开始删除消息;
- x-overflow:设置队列溢出行为。这决定了当达到队列的最大长度时消息会发生什么。有效值是drop-head、reject-publish或reject-publish-dlx。仲裁队列类型仅支持drop-head;
- x-dead-letter-exchange:死信交换器名称,过期或被删除(因队列长度超长或因空间超出阈值)的消息可指定发送到该交换器中;
- x-dead-letter-routing-key:死信消息路由键,在消息发送到死信交换器时会使用该路由键,如果不设置,则使用消息的原来的路由键值
- x-single-active-consumer:表示队列是否是单一活动消费者,true时,注册的消费组内只有一个消费者消费消息,其他被忽略,false时消息循环分发给所有消费者(默认false)
- x-max-priority:队列要支持的最大优先级数;如果未设置,队列将不支持消息优先级;
- x-queue-mode(Lazy mode):将队列设置为延迟模式,在磁盘上保留尽可能多的消息,以减少RAM的使用;如果未设置,队列将保留内存缓存以尽可能快地传递消息;
- x-queue-master-locator:在集群模式下设置镜像队列的主节点信息。
(3) 添加用户
用户角色与权限控制:
- administrator:超级管理员,能够登录后台,能够查看所有信息,修改所有的 Exchange、Queue、Bindings 等策略
- monitoring:监控者,能够登录后台,能够查看所有的信息,但是,只能修改属于自己的 Exchange、Queue、Bindings 等策略
- policymaker:策略制定者,能够登录后台,不能查看节点的信息(Overview),但是,能够修改属于自己的 Exchange、Queue、Bindings 等策略
- management:普通管理这,能够登录后台,不能查看节点的信息(Overview),不能修改属于自己的Exchange、Queue、Bindings 等策略,但是能够查看
- None:无法登录后台