springboot与消息—使用、原理、整合RabbitMQ

     应用场景:异步处理、应用解耦、流量削峰

     消息队列主要有两种形式的目的地:队列(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层的协议标准
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值