RabbitMQ简介

RabbitMQ是一个开源的消息代理的队列服务器,用来通过普通协议在完全不同的应用之间共享数据。

RabbitMQ是使用Erlang语言来编写的,并且RabbitMQ是基于AMQP协议的。Erlang语言在数据交互方面性能优秀,有着和原生Socket一样的延迟,这也是RabbitMQ高性能的原因所在。可谓“人如其名”,RabbitMQ像兔子一样迅速。

RabbitMQ除了像兔子一样跑的很快以外,还有这些特点:

  • 开源、性能优秀,稳定性保障
  • 提供可靠性消息投递模式、返回模式
  • 与Spring AMQP完美整合,API丰富
  • 集群模式丰富,表达式配置,HA模式,镜像队列模型
  • 保证数据不丢失的前提做到高可靠性、可用性

MQ典型应用场景

  • 异步处理。把消息放入消息中间件中,等到需要的时候再去处理。
  • 流量削峰。例如秒杀活动,在短时间内访问量急剧增加,使用消息队列,当消息队列满了就拒绝响应,跳转到错误页面,这样就可以使得系统不会因为超负载而崩溃。
  • 日志处理
  • 应用解耦。假设某个服务A需要给许多个服务(B、C、D)发送消息,当某个服务(例如B)不需要发送消息了,服务A需要改代码再次部署;当新加入一个服务(服务E)需要服务A的消息的时候,也需要改代码重新部署;另外服务A也要考虑其他服务挂掉,没有收到消息怎么办?要不要重新发送呢?是不是很麻烦,使用MQ发布订阅模式,服务A只生产消息发送到MQ,B、C、D从MQ中读取消息,需要A的消息就订阅,不需要了就取消订阅,服务A不再操心其他的事情,使用这种方式可以降低服务或者系统之间的耦合。

RabbitMQ和AMQP协议

提到RabbitMQ,就不得不提AMQP协议。AMQP协议是具有现代特征的二进制协议。是一个提供统一消息服务的应用层标准高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。

AMQP :Advanced Message Queue,高级消息队列协议。它是应用层协议的一个开放标准,为面向消息的中间件设计,基于此协议的客户端与消息中间件可传递消息,并不受产品、开发语言等条件的限制。

RabbitMQ基本概念

以下介绍几个AMQP的几个重要概念:

  • Server:接收客户端的连接,实现AMQP实体服务。
  • Connection:连接,应用程序与Server的网络连接,TCP连接。
  • Channel:信道,消息读写等操作在信道中进行。客户端可以建立多个信道,每个信道代表一个会话任务。
  • Message:消息,应用程序和服务器之间传送的数据,消息可以非常简单,也可以很复杂。有Properties和Body组成。Properties为外包装,可以对消息进行修饰,比如消息的优先级、延迟等高级特性;Body就是消息体内容。
  • Virtual Host:虚拟主机,用于逻辑隔离。一个虚拟主机里面可以有若干个Exchange和Queue,同一个虚拟主机里面不能有相同名称的Exchange或Queue。
  • Exchange:交换器,接收消息,按照路由规则将消息路由到一个或者多个队列。如果路由不到,或者返回给生产者,或者直接丢弃。RabbitMQ常用的交换器常用类型有direct、topic、fanout、headers四种,后面详细介绍。
  • Binding:绑定,交换器和消息队列之间的虚拟连接,绑定中可以包含一个或者多个RoutingKey。
  • RoutingKey:路由键,生产者将消息发送给交换器的时候,会发送一个RoutingKey,用来指定路由规则,这样交换器就知道把消息发送到哪个队列。路由键通常为一个“.”分割的字符串,例如“com.rabbitmq”。
  • Queue:消息队列,用来保存消息,供消费者消费。

如下图是AMQP的协议模型:

1630578921560

AMQP协议模型有三部分组成:生产者消费者服务端

生产者是投递消息的一方,首先连接到Server,建立一个连接,开启一个信道;然后生产者声明交换器和队列,设置相关属性,并通过路由键将交换器和队列进行绑定。同理,消费者也需要进行建立连接,开启信道等操作,便于接收消息。

接着生产者就可以发送消息,发送到服务端中的虚拟主机,虚拟主机中的交换器根据路由键选择路由规则,然后发送到不同的消息队列中,这样订阅了消息队列的消费者就可以获取到消息,进行消费。

RabbitMQ 是 AMQP 协议的一个开源实现,两者十分像,所以其内部实际上也是 AMQP 中的基本概念:

1630598377115

RabbitMQ Exchange类型

RabbitMQ常用的交换器类型有direct、topic、fanout、headers四种。

  • Direct Exchange

    该类型的交换器将所有发送到该交换器的消息被转发到RoutingKey指定的队列中,也就是说路由到BindingKey和RoutingKey完全匹配的队列中。

    路由键与队列名完全匹配,如果一个队列绑定到交换机要求路由键为

    “dog”,则只转发 routing key 标记为“dog”的消息,不会转发

    “dog.puppy”,也不会转发“dog.guard”等等。它是完全匹配、单播的模式。

  • Topic Exchange

    该类型的交换器将所有发送到Topic Exchange的消息被转发到所有RoutingKey中指定的Topic的队列上面。

    Exchange将RoutingKey和某Topic进行模糊匹配,其中“”用来匹配一个词,“#”用于匹配一个或者多个词。例如“com.#”能匹配到“com.rabbitmq.oa”和“com.rabbitmq”;而"login.“只能匹配到“com.rabbitmq”。

  • Fanout Exchange

    该类型不处理路由键,会把所有发送到交换器的消息路由到所有绑定的队列中。很像子网广播,每台子网内的主机都获得了一份复制的消息。fanout 类型转发消息是最快的。

    优点是转发消息最快,性能最好。

  • Headers Exchange

    该类型的交换器不依赖路由规则来路由消息,而是根据消息内容中的headers属性进行匹配。headers类型交换器性能差,在实际中并不常用。

RabbitMQ的安装

为了偷懒和便捷,这边我是使用了docker加以安装的;

  • 进入官方下载地址,选择使用Docker安装,跳转到dockerhub查看镜像。

  • 选择3.x.x-beta.4-management进行安装,带有management是含有管理界面的。

  • 拉取镜像和启动

    docker run -d --hostname my-rabbit -p 5672:5672 -p 15672:15672 rabbitmq:3.8.0-beta.4-management

  • 查看镜像

    1630599448914

  • 可用浏览器访问localhost:15672,如果是装在虚拟机上面的话,需要打开虚拟机ip:15672:

    1630599622801

RabbitMQ配置

RabbitMQ管理命令行

1
2
3
4
5
6
# 1.服务启动相关
systemctl start|restart|stop|status rabbitmq-server
# 2.管理命令行  用来在不使用Web管理界面情况下命令操作RabbitMQ
rabbitmqctl help  可以查看更多命令
# 3.插件管理命令行
rabbitmqplugins enable|list|disable

1630577588407

1630577678657

1630577811465

Web管理界面介绍

overview概览

1630578070154

1630578761319

mq实现了系统的解耦或者是系统之间的通信;(可以把消息直接发给队列, 也可以发给exchange)

rabbitmq官网上的七种消息模型

1630579576118

1630579611206

3.7版本中还不支持发布确认模式, 不过前面的6种消息模型也应该够用了;

参考资料