消息协议与消息中间件

消息协议

参考:Choosing Your Messaging Protocol
都基于TCP/IP协议
OASIS组织官网, Organization for Advancement of Structured Information

1、AMQP(advanced message queuing protocol)

支持 AMQP协议的消息代理(message broker):RabbitMQ
特点:可靠性和互操作性,基于二进制流传输

它提供了与消息传递相关的各种功能包括:

  • 基于主题的发布和订阅消息传递 —— 细粒度控制
  • 可靠的排队 —— 通过限制对队列的访问,管理其深度
  • 灵活的路由 —— AMQP直接以扇出形式,按主题和基于主题交换路由消息
  • 事务和安全性 —— 提高可靠性
  • 消息包含属性,注释和标题 —— 适用于业务场景

为了在不用应用、公司之间实现互操作性,相对于其他协议,AMQP的采用率最高。

由于RabbitMQ,支持多种语言,同时已经存在了大量的使用实例,因此 使用RabbitMQ是作为构建大规模,可靠,弹性或传递群集架构基础消息的良好选择。

2、MQTT(message queue telemetry transport)

支持 MQTT协议的消息代理(message broker):Eclipse MosquittoRabbitMQ
特点:简单性,基于二进制流传输

没有队列,与AMQP相比,消息更加简单(simplicity,so it’s low footprint),(focus)专注应用于资源受限、低带宽、高延迟的设备(如拨号线路和卫星链接),可以在嵌入式系统中获得高效作用。

MQTT消息只包含一个紧凑的有效负载(为二进制数据包。没有消息属性、压缩消息头,比基于文本的HTTP更简洁),一些基于MQTT的消息代理并发支持几千的设备连接。

由 IBM公司开源,设计目的是为了控制受低带宽限制的设备(如物联设备),在设备之间发布和订阅主题(topic),进行数据对话或发出控制命令(command mesaage)等功能。
在这里插入图片描述

3、STOMP(simple/streaming text oriented message protocol)

支持 STOMP协议的消息代理(message broker):RabbitMQ
特点:简单性和互操作性,基于本文流传输(HTTP/1.x 也是基于有序阻塞的文本流实现,但HTTP/2 基于多路复用的二进制流实现)

它提供了与消息传递相关的各种功能包括:

  • 基于目标(destination)的发布和订阅消息传递 —— 细粒度控制
  • 事务和安全性 —— 提高可靠性
  • 消息包含属性,注释和标题 —— 适用于业务场景

由于 STOMP不处理主题或队列,也没有消息与destination的规范映射方式,因此 STOMP代理必须实现映射destination到内部理解的内容,例如主题topic,队列queue或交换exchange,不同broker可以有不同的内部映射机制。

RabbitMQ Web Stomp 实现了通过websockets在浏览器中暴露消息,可以使用任意类型的信息实时更新浏览器,移动应用程序或机器。

4、其他用于传递消息到web的协议

http/2

websocket

STOMP Over WebSocket

为了能够从server端向client端推送实时数据,利用sockjs\stomp协议、从kafka中发布推送数据的springboot项目

由于分布式系统中,前端消息请求经过负载均衡后,不能保证都转发到那一台已经建立连接的server机器上,因此
利用node.js的kafka-node, 前端直连kafka进行通信;
或者kakfa连接stomp connector;

WebSockets通过建立单个TCP连接,提供了双向通信通道。 客户端通过“WebSocket握手”建立持久连接,该连接允许实时交换消息。

消息中间件\消息代理

消息代理作为主题(topic)与消息的控制者,负责接受、过滤消息,并根据客户(client)订阅的主题,转发消息给指定客户。
在这里插入图片描述

1、activeMQ

2、rabbitMQ

支持多种消息协议:AMQP\MQTT\STOMP

3、rocketMQ

4、kafka

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值