应用场景:异步处理、应用解耦、流量削峰
消息队列主要有两种形式的目的地:队列(queue):点对点消息通信(point-to-point);主题(topic):发布(publish)/订阅(subscribe)消息通信。
JMS(Java Message Service)JAVA消息服务:基于JVM消息代理的规范。ActiveMQ、HornetMQ是JMS实现。
AMQP(Advanced Message Queuing Protocol):高级消息队列协议,也是一个消息代理的规范,兼容JMS;RabbitMQ是AMQP的实现。
Spring Boot自动配置:JmsAutoConfiguration、RabbitAutoConfiguration。比较:
JMS | AMQP | |
定义 | Java api | 网络线级协议 |
跨语言 | 否 | 是 |
跨平台 | 否 | 是 |
Model | 提供两种消息模型: 1、Peer-2-Peer(点对点) 2、Pub/sub(发布订阅模型) |
提供了五种消息模型: 1、direct exchange(点对点) 2、fanout exchange 3、topic change 4、headers exchange 5、system exchange 本质来讲,后四种和JMS的pub/sub模型没有太大差别,仅是在路由机制上做了更详细的划分; |
支持消息类型 | 多种消息类型:TextMessage、MapMassage、BytesMessage、StreamMessage、ObjectMassage、Message | byte[] 当实际应用时,有复杂的消息,可以将消息序列化后发送。 |
综发评价 | JMS定义了JavaAPI层面的标准;在java体系中,多个client均可通过JMS进行交互,不需要应用修改代码,但是其对跨平台的支持较差。 | AMQP定义了wire level层的协议标准 |