一. RabbitMQ 安装
我们对于 RabbitMQ 已经有了简单的了解, 接下来进行 RabbitMQ 的安装
RabbitMQ 是⼀套开源的消息队列服务软件, 基于 Erlang 语言编写, 所以安装RabbitMQ 之前, 需要先安装部署 Erlang 环境, 再安装 RabbitMQ 环境.
RabbitMQ 大多部署在 Linux 操作系统
此处不做详细安装教程~
二. RabbitMQ 核心概念
在安装完 RabbitMQ 之后, 接下来学习如何去使用 RabbitMQ
来到 RabbitMQ 管理界面
界面上的导航栏共分6部分, 这6部分分别是什么意思呢, 我们先看看 RabbitMQ 的工作流程
RabbitMQ 是⼀个消息中间件, 也是⼀个生产者消费者模型. 它负责接收, 存储并转发消息
消息传递的过程类似邮局.
当你要发送⼀个邮件时,你把你的邮件放到邮局,邮局接收邮件, 并通过邮递员送到收件人的手上
按照这个逻辑, Producer 就类似邮件发件人. Consumer 就是收件人, RabbitMQ 就类似于邮局
2.1 Producer 和 Consumer
- Producer: 生产者, 是 RabbitMQ Server 的客户端, 向 RabbitMQ 发送消息
- Consumer: 消费者, 也是 RabbitMQ Server 的客户端, 从 RabbitMQ 接收消息
- Broker:其实就是 RabbitMQ Server, 主要是接收和收发消息
- 生产者 (Producer) 创建消息, 然后发布到 RabbitMQ 中. 在实际应用中, 消息通常是⼀个带有⼀定业务逻辑结构的数据, 比如 JSON 字符串. 消息可以带有⼀定的标签, RabbitMQ 会根据标签进行路由, 把消息发送给感兴趣的消费者(Consumer).
- 消费者连接到 RabbitMQ 服务器, 就可以消费消息了, 消费的过程中, 标签会被丢掉. 消费者只会收到消息, 并不知道消息的生产者是谁, 当然消费者也不需要知道.
- 对于 RabbitMQ 来说,⼀个 RabbitMQ Broker 可以简单地看作⼀个 RabbitMQ 服务节点, 或者 RabbitMQ 服务实例. 大多数情况下也可以将⼀个 RabbitMQ Broker 看作⼀台 RabbitMQ 服务器
2.2 Connection 和 Channel
Connection: 连接. 是客户端和 RabbitMQ 服务器之间的⼀个 TCP 连接. 这个连接是建立消息传递的基础, 它负责传输客户端和服务器之间的所有数据和控制信息.
Channel: 通道, 信道. Channel 是在 Connection 之上的⼀个抽象层. 在 RabbitMQ 中, ⼀个 TCP 连接可以有多个 Channel, 每个 Channel 都是独立的虚拟连接. 消息的发送和接收都是基于 Channel 的
通道的主要作用是将消息的读写操作复用到同⼀个 TCP 连接上,这样可以减少建立和关闭连接的开销,提高性能
2.3 Virtual host
Virtual host: 虚拟主机. 这是⼀个虚拟概念. 它为消息队列提供了⼀种逻辑上的隔离机制. 对于 RabbitMQ 而言, ⼀个 BrokerServer 上可以存在多个 Virtual Host. 当多个不同的用户使用同⼀个RabbitMQ Server 提供的服务时,可以虚拟划分出多个 vhost,每个用户在自己的 vhost 创建 exchange/queue 等
类似 MySQL 的 “database”, 是⼀个逻辑上的集合. ⼀个 MySQL 服务器可以有多个 database
2.4 Queue
Queue: 队列, 是 RabbitMQ 的内部对象, 用于存储消息
多个消费者, 可以订阅同⼀个队列
2.5 Exchange
Exchange: 交换机. message 到达 broker 的第⼀站, 它负责接收生产者发送的消息, 并根据特定的规则把这些消息路由到⼀个或多个 Queue 列中.
Exchange 起到了消息路由的作用,它根据类型和规则来确定如何转发接收到的消息
类似于发快递之后, 物流公司怎么处理呢, 根据咱们的地址来分派这个快递到不同的站点, 然后再送到收件人手里. 这个分配的工作,就是交换机来做的
2.6 RabbitMQ 工作流程
理解了上面的概念之后, 再来回顾⼀下这个图, 来看 RabbitMQ 的工作流程
- Producer 生产了⼀条消息
- Producer 连接到 RabbitMQBroker, 建立⼀个连接 (Connection),开启⼀个信道(Channel)
- Producer 声明⼀个交换机 (Exchange), 路由消息
- Producer 声明⼀个队列 (Queue), 存放信息
- Producer 发送消息至 RabbitMQ Broker
- RabbitMQ Broker 接收消息, 并存入相应的队列 (Queue) 中, 如果未找到相应的队列, 则根据生产者的配置, 选择丢弃或者退回给生产者
如果我们把 RabbitMQ 比作⼀个物流公司,那么它的⼀些核心概念可以这样理解:
- Broker就类似整个物流公司的总部, 它负责协调和管理所有的物流站点, 确保包裹安全、⾼效地送达.
- Virtual Host 可以看作是物流公司为不同的客户或业务部门划分的独立运营中⼼. 每个运营中心都有自己的仓库(Queue), 分拣规则(Exchange)和运输路线(Connection和Channel), 这样可以确保不同客户的包裹处理不会相互干扰, 同时提供定制化的服务
- Exchange 就像是站点里的分拣中心. 当包裹到达时, 分拣中心会根据包裹上的标签来决定这个包裹应该送往哪个目的地(队列). 快递站点可能有不同类型的分拣中心, 有的按照具体地址分拣, 有的将包裹复制给多个收件人等.
- Queue 就是快递站点里的⼀个个仓库, 用来临时存放等待派送的包裹. 每个仓库都有⼀个或多个快递员(消费者)负责从仓库中取出包裹并派送给最终的收件人.
- Connection 就像是快递员与快递站点之间的通信线路. 快递员需要通过这个线路来接收派送任务(消息).
- Channel 就像是快递员在执行任务时使用的多个并行的通信线路. 这样,快递员可以同时处理多个包裹, 比如⼀边派送包裹, ⼀边接收新的包裹
三. AMQP
AMQP(Advanced Message Queuing Protocol)是⼀种高级消息队列协议, AMQP 定义了⼀套确定的消息交换功能, 包括交换器(Exchange), 队列(Queue) 等. 这些组件共同工作, 使得生产者能够将消息发送到交换器. 然后由队列接收并等待消费者接收. AMQP 还定义了⼀个网络协议, 允许客户端应用通过该协议与消息代理和 AMQP 模型进行交互通信
RabbitMQ 是遵从 AMQP 协议的,换句话说,RabbitMQ 就是 AMQP 协议的 Erlang 的实现(当然 RabbitMQ 还支持 STOMP2, MQTT2 等协议). AMQP 的模型结构和 RabbitMQ 的模型结构是⼀样的
四. web界面操作
RabbitMQ 管理界面上的 Connections,Channels, Exchange, Queues 就是和上面流程图的概念是⼀样的, Overview 就是视图的意思, Admin 是用户管理.
我们在操作 RabbitMQ 前, 需要先创建 Virtual host
接下来看具体操作:
4.1 用户相关操作
添加用户
a) 点击 Admin -> Add user
b) 设置账号密码及权限
①: 设置账号
②: 设置密码
③: 确认密码
④: 设置权限
添加完成后, 点击[Add user]
c) 观察用户是否添加成功
用户相关操作
a) 点击要删除的用户, 查看用户详情
b) 在用户详情页面,进行更新或删除操作
- 设置对虚拟机的操作权限
- 更新/删除用户
退出当前用户
4.2 虚拟主机相关操作
创建虚拟主机
在 Admin 标签页下, 点击右侧 Virtual Hosts -> Add a new virtual host
设置虚拟主机名称
观察设置结果
此操作会为当前登录用户设置虚拟主机
五. RabbitMQ 快速入门
步骤:
- 引入依赖
- 编写生产者代码
- 编写消费者代码
5.1 引入依赖
<dependency>
<groupId>com.rabbitmq</groupId>
<artifactId>amqp-client</artifactId>
<