【MQ】RabbitMQ 安装

一、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
图片.png

可以看出 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

图片.png

  • Name:设置交换器的名称,用来标识 Exchange, 同一个 Virtual Host 中交换器的名称不能重复
  • Type:设置交换器的类型,常用的类型有:fanout、direct、topic
  • Durability:设置交换器是否持久化,Durable-持久化,Transient-非持久化
  • Auto delete:设置交换器是否自动删除,Yes - 当交换器与队列的最后一个解绑时,交换器将自动删除
  • Internal:设置交换器是否为内部专用,Yes - 表示内部专用,客户端不能向交换器投递消息
  • Arguments:参数列表,这是 AMQP 协议留给 RabbitMQ 做扩展用的

(2) 添加 Queue

图片.png

  • 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) 添加用户

图片.png

用户角色与权限控制:

  • administrator:超级管理员,能够登录后台,能够查看所有信息,修改所有的 Exchange、Queue、Bindings 等策略
  • monitoring:监控者,能够登录后台,能够查看所有的信息,但是,只能修改属于自己的 Exchange、Queue、Bindings 等策略
  • policymaker:策略制定者,能够登录后台,不能查看节点的信息(Overview),但是,能够修改属于自己的 Exchange、Queue、Bindings 等策略
  • management:普通管理这,能够登录后台,不能查看节点的信息(Overview),不能修改属于自己的Exchange、Queue、Bindings 等策略,但是能够查看
  • None:无法登录后台
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容