一,Spring Boot与消息服务概述:
做消息中间件的主要有:JMS,AMQP,RabbitMQ
- 大多应用中,可通过消息服务中间件来提升系统异步通信,扩展解耦能力
- 消息服务中两个重要概念:
消息代理(message broker)和目的地(destination)
当消息发送者发送消息以后,将由消息代理接管,消息代理保证消息传递到指定目的地 - 消息队列主要有两种形式的目的地
1).队列(queue):点对点消息通信(point-to-point)
2).主题(topic):发布(publish)/订阅(subscribe)消息通信 - 点对点式:
-消息发送者发送消息,消息代理将其放入一个队列中,消息接收者从队列中获取息内容,消息读取后被移出队列
-消息只有唯一的发送者和接收者,但并不是说只能有一个接收者 - 发布订阅式
-发送者(发布者)发送消息到主题,多个接收者(订阅者)监听(订阅)这个主题,那么就会在消息到达时同时收到消息 - JMS(Java Message Service)JAVA消息服务:
-基于JVM消息代理的规范,ActiveMQ,HornetMQ是JMS实现 - AMQP(Advanced Message Queuing Protocol)
-高级消息队列协议,也是一个消息代理的规范,兼容JMS
-RabbitMQ是AMQP的实现
JMS | AMQP | |
---|---|---|
定义 | Java api | 网络线级协议 |
跨语言 | 否 | 是 |
跨平台 | 否 | 是 |
Model | 提供两种消息模型:1).Peer-2-P |