1. 简介:
RabbitMQ是一个在AMQP基础上可复用的企业消息系统。
AMQP(Advanced(预先) Message Queuing Protocol(协议)) 是一个提供统一消息服务的应用层标准协议,基于此协议的 客户端与消息中间件可传递消息,
并不受客户端中间件不同产品,不同开发语言的限制。
RabbitMQ 遵循AMQP协议,用erlang语言开发,用来通过协议在完全不同应用之间共享数据,
或者将作业排队以便让分布式服务器进行处理。
2. 组件说明
1. Broker: 消息队列服务器实体
2. Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列。
3. Queue: 消息队列的载体,每个消息都会被投入到一个,或多个队列。
4. Binding: 绑定,它的作用就是把exchange和队列按照一定的规则绑定起来。
5. Routing Key : 路由关键字,exchange 根据这个关键字进行消息投递,
6. channel: 消息通道,在客户端的每个链接里,可建立多个channel,每个channel
代表一个绘画任务。
7. vhost: 虚拟主机,一个broker中可开设多个vhost,用作不同用户的权限分离。
8. producer: 消息生产者。
9. consumer: 消息消费者。
10. 消息队列的使用过程:
(1)生产者链接到服务器,声明一个exchange,并设置交换机类型等属性。
(2)消费者 连接到消息队列服务器,打开一个channel
(3)消费者 声明一个queue,并设置相关属性。
(4)消费者 使用routing key, 绑定 exchange 和 queue。
(5)生产者 投递消息到exchange
(6)exchange 接收到消息后,根据消息的key和已经设置的binding,进行消息路由,将消息
投递到一个或多个队列。
总结:
使用rabbitmq 可以解耦应用程序,使用消息在应用程序中进行传递,
将一些无需及时返回且耗时的操作提取出来,进行异步处理,可节省服务器相应时间,
提高系统吞吐量。
2. 安装
安装rabbitmq前,先要安装erlang 并配置好环境变量(erlang_home, path 都要设)。
2.1. 监测erlang 是否安装好的方法是:
cmd到erlang安装目录的bin文件夹下:
erl -version
2.2 监测rabbitmq是否安装好的方法是:
cmd到安装目录的sbin目录下,运行
rabbitmqctl status
3. springboot 使用 rabbitmq 示例:
Rabbit MQ 服务器 会根据路由键将消息从交换路由到消息队列中,如何处理投递多个队列的情况?
这里不同类型的交换机起到了重要作用。分别是 fanout,direct,topic, 每种类型实现了不同的路由算法。
3.1 使用 Fanout Exchange 交换机
当使用Fanout Exchange 时,无需处理路由键,很像子广播,
每一台与该交换机绑定的队列都会获得一份消息。
Fanout 交换机处理消息是最快的。
示例:
1 所需依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
2 加载交换机,队列,到容器,并绑定。
/**
* 初始化Fanout交换机和队列,并将其绑定
* */
@Configuration
public class FanoutConfig {
// 初始化创建交换机
@Bean
public Fanout