SpringBoot学习-part57 JMS & AMQP 简介

1.大多应用中,可通过消息服务中间件来提升系统的异步通信,扩展解耦能力。

2.消息服务汇总两个重要概念:
消息代理(message broker)
目的地(destination)
当消息发送者发送消息后,将由消息代理接管,消息代理保证消息传递到指定的目的地。

3.消息队列主要有两种形式的目的地。
队列(queue):点对点消息通信(p2p)
主题(topic):发布(publish)/订阅(subscribe)消息通信

4.点对点式:
每一条消息只有唯一的接受者,被接收后的消息将从消息队列中移除。

5.发布订阅式:
发布者发布消息大主题,多个接收者订阅监听这个主题,发布的消息会被多个监听者接收。

6.JMS(java message service) Java消息服务

基于JVM消息代理的规范,ActiveMQ、HornetMQ是对JMS的实现。

7.AMQP(Advanced Message Queuing Protocol)

高级消息队列协议,也就是一个消息代理的规范,兼容JMS
RabbitMQ是AMQP的实现。
JMSAMQP
定义java api网络线级协议
跨语言
跨平台
Model提供两种模型:
(1)peer-2-peer
(2) pub/sub
提供了五种消息模型:
(1) direct exchange
(2)fanout exchange
(3)topic change
(4)headers exchange
system exchange
本质上来讲后面四种和JMS的pub/sub模型没有
太大差别,仅是在路由机制上做了更详细的划分。
支持的消息类型多种消息类型:
TextMessage
MapMessage
BytesMessage
StreamMessage
ObjectMessage
Message(只有消息头和属性)
byte[]
实际应用中,有复杂的消息,可以序列化后发送。
综合评价JMS定义了JAVA API层面的标准;在java体系中,多个client
均可以通过JMS进行交互,不需要应用修改代码,但是跨平台性较差。
AMQP定义了wire-level层的协议标准;天然具有跨平台、跨语言特性。

8.Spring支持

  • spring-jms提供了对JMS的支持
  • spring-rabbit提供了对AMQP的支持
  • 需要ConnectionFactory的实现来连接消息代理
  • 提供了JmsTemplate、RabbitTemplate来发送消息
  • @JmsListener(JMS)、@RabbitListener(AMQP)注解在方法上监听消息代理发布的消息
  • @EnableJms、@EnableRabbit开启支持

9.SpringBoot自动配置

  • JmsAutoConfiguration
  • RabbitAutoConfiguration
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值