五、AMQP 协议
上一篇文章《Docker安装》
什么是 AMQP
AMQP全程:Advanced Message Queuing Protocol(高级消息队列协议)。应用层协议的一个开发标准,为面向消息的中间件设计
5.1 消息队列中的生产者和消费者流转
AMQP 生产者流转过程
AMQP 消费者流转过程
5.2 RabbitMQ 的核心组成部分
核心概念:
- Server:又称为
Broker
,接受客户端的连接,实现 AMQP 实体服务。安装 rabbitmq-server - Connection:连接,应用程序与 Broker 的网络连接 TCP/IP 三次握手和四次握手
- Channel:网络信道,几乎所有的操作都在 Channel 中进行,Channel 是进行消息读写的通道,客户端可以建立对各 Channel,每个Channel代表一个会话任务
- Message:消息,服务于应用程序之间传送的数据,由 Properties 和 body 组成,Properties 可对消息进行修饰,比如消息的优先级,延迟等高级特性,body就是消息体的内容
- Virtual Host:虚拟地址,用于进行逻辑隔离,最上层的消息路由,一个虚拟机里可以有多个 Exchange 和 Queue,同一个虚拟主机里面不能有相同名字的 Exchange
- Exchange:交换机,接收消息,根据路由键发送消息到绑定队列(不具备消息存储能力)
- Bindings:Exchange 和 Queue 之间的虚拟连接,binding 中可以保护多个 routing key
- Routing key:是一个路由规则,虚拟机可以用它来确定如何路由一个特定消息
- Queue:队列,也称为 Message Queue 消息队列,保存消息并将它们发送给消费者
Bindings
推荐:建议指定交换机,不要使用默认交换机
Routing key
当交换机接收到信道里的消息之后,队列可根据路由,选择性地将消息发送给消费者
RabbitMQ 的运行流程
代码过程
5.3 RabbitMQ 支持消息的模式
参考官网:https://www.rabbitmq.com/getstarted.html
1)简单模式 Simple
2)工作模式 Work
3)发布订阅模式
4)路由模式
5)主题 Topics 模式
6)参数模式
界面化发送消息
界面化接收消息
下一篇文章《入门案例》
本文含有隐藏内容,请 开通VIP 后查看