文章目录
消息协议
参考: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 Mosquitto、RabbitMQ、
特点:简单性,基于二进制流传输
没有队列,与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
为了能够从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