AMQP高级消息队列协议与模型以及核心概念

什么是AMQP高级消息队列协议

AMQP,即Advanced Message Queuing Protocol,是具有现代特征的二进制协议。是一个提供统一消息服务的应用层标准高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。(说白了就是规范,开发时得按照规范要求来做)

AMQP协议模型

AMQP高级消息队列协议与模型以及核心概念_第1张图片

AMQP核心概念

  • Server:又称Broker,接受客户端的连接,实现AMQP实体服务
  • Connection:顾名思义,用于应用程序与Broker的网络连接
  • Channel:网络信道,几乎所有的操作都在Channel中进行,Channel是进行消息读写的通道。客户端可建立多个Channel,每一个Channel代表一个会话任务。这个类似NIO中channel通道
  • Message:消息,服务器和应用程序之间传送的数据,由Properties和Body组成。Properties可以对消息进行修饰,比如消息的优先级、延迟等高级特性;Body则是表示消息体的内容
  • Virtual host:虚拟地址,用于进行逻辑隔离,是最上层的消息路由。一个Virtual host里面可以有若干个Exchange和Queue,同一个Virtual Host里面不能有相同名称的Exchange或Queue
  • Exchange:交换机,接收消息,根据路由键转发消息到绑定的队列中
  • Binding:Exchange和Queue之间的虚拟连接,binding中可以包含routing key
  • Routing key:一个路由规则,虚拟机可用它来确定如何路由一个特定消息
  • Queue:也称为Message Queue(消息队列),用于保存消息并将它转发给消费者

RabbitMQ的整体架构

AMQP高级消息队列协议与模型以及核心概念_第2张图片

RabbitMQ消息是如何进行流转的

AMQP高级消息队列协议与模型以及核心概念_第3张图片

你可能感兴趣的:(RabbitMQ)