什么是AMQP

AMQP全称:Advanced Message Queuing Protocol(高级消息队列协议)。是应用层协议的一个开发标准,为面向消息的中间件设计。

AMQP生产者流转过程

Spring rabbitMQ 流控制_TCP

AMQP消费者流转过程

Spring rabbitMQ 流控制_java_02

RabbitMQ的核心组成部分

01、RabbitMQ的核心组成部分

Spring rabbitMQ 流控制_Spring rabbitMQ 流控制_03


核心概念:

Server:又称Broker ,接受客户端的连接,实现AMQP实体服务。 安装rabbitmq-server

Connection:连接,应用程序与Broker的网络连接 TCP/IP/ 三次握手和四次挥手

Channel:网络信道,几乎所有的操作都在Channel中进行,Channel是进行消息读写的通道,客户端可以建立对各Channel,每个Channel代表一个会话任务。

Message :消息:服务与应用程序之间传送的数据,由Properties和body组成,Properties可是对消息进行修饰,比如消息的优先级,延迟等高级特性,Body则就是消息体的内容。

Virtual Host 虚拟地址,用于进行逻辑隔离,最上层的消息路由,一个虚拟主机理由可以有若干个Exhange和Queueu,同一个虚拟主机里面不能有相同名字的Exchange

Exchange:交换机,接受消息,根据路由键发送消息到绑定的队列。(不具备消息存储的能力)

Bindings:Exchange和Queue之间的虚拟连接,binding中可以保护多个routing key.

Routing key:是一个路由规则,虚拟机可以用它来确定如何路由一个特定消息。

Queue:队列:也成为Message Queue,消息队列,保存消息并将它们转发给消费者。

简述流程:生产者于rabbitmq建立起连接,并开启多个传递消息的通道,将消息投递到rabbitmq服务器,然后由服务器的交换机将消息根据一定的路由规则将消息投递到与其绑定的相关队列,队列将消息的存储并转发给目标消费者。

02、RabbitMQ整体架构是什么样子的?

Spring rabbitMQ 流控制_java_04

03、RabbitMQ的运行流程

Spring rabbitMQ 流控制_Spring rabbitMQ 流控制_05

RabbitMQ 为什么需要信道?为什么不是TCP直接通信?

  1. TCP的创建和销毁,开销大,创建需要三次握手,销毁需要四次分手
  2. 如果不使用信道,那么引用程序就会使用TCP的方式连接到rabbitmq,高峰时每秒成千上万条连接会造成资源的巨大浪费(一条tcp消耗资源,成千上万的tcp会非常消耗资源),而且操作系统每秒处理TCP连接数量也是有限的,必定会造成性能瓶颈
  3. 信道的原理是一条线程一条信道,多条线程多条信道共同使用一条TCP连接。一条TCP连接可以容纳无限的信道,及时每秒造成成千上万的请求也不会造成性能瓶颈

可以存在没有交换机的队列吗?

  1. 交换器是通过路由键和队列绑定在一起的,如果消息拥有的“路由键”跟队列和交换器的“路由键”匹配,那么消息就会被路由到该绑定的队列当中去
  2. 也就是说,消息到队列的过程中,消息首先会经过交换器,接下来交换器再通过路由键匹配,分发消息到具体的队列中去
  3. 路由键可以就是为匹配的规则