Message Queue-消息队列

简述

在计算机科学中,消息队列(Message Queue,MQ)是一种进程间通信或者同一进程的不同线程间的通信方式。MQ允许应用程序间通过发送消息来进行通信,当目标程序繁忙或者掉线,来不及处理消息,MQ会提供暂时的消息存储。


image.png | center | 364x284

MQ中有两个关键字:

  • 消息:发送方与接收方之间传递的数据,其实际上就是一些带有头信息的字节数组。
  • 队列:一种数据结构,按照消息发送的时间顺序排列,先进先出。

MQ使用异步通信协议(asynchronous communications protocol),消息发送者将消息放入MQ中后,无需等待接收者的响应,通信效率较高。电子邮件就是一个使用异步消息,非常合适的例子。

特点


image.png | center | 451x221

优点:

  • 使用了异步消息处理,提高了系统的响应速度,用户体验更好;
  • 发送方与接收方之间实现了逻辑和物理上的解耦,两者可以独立开发,甚至使用不同的语言来实现。

缺点:

  • 系统更为复杂,消息传递路径更长,延时会增加;
  • 消息的可靠性依赖于MQ,消息可能丢失,但用户已经收到success通知。

规范

三种常见的开源消息队列协议:


image.png | center | 200x176

  • 高级消息队列协议(Advanced Message Queuing Protocol,AMQP):功能丰富的二进制消息队列协议,于2014年被批准为ISO&IEC国际标准;

  • 面向简单文本消息协议(Simple/Streaming Text Oriented Messaging Protocol,STOMP):基于文本消息,是一个简单、轻量级的消息协议,与HTTP协议相似;

  • 消息队列遥测传输(Message Queue Telemetry Transport,MQTT):是为大量计算能力有限,且工作在低带宽、不可靠的网络的远程传感器和控制设备通讯而设计的协议,是物联网(IOT)生态系统中重要的组成部分。

很容易被提及的还有JMS(Java Message Service),Java社区中最常见的消息系统标准,Java EE规范之一,常常被用来与AMQP做比较。JMS的局限性在于其定义了一系列API,却没有定义消息传输的格式,对跨语言、跨平台的特性支持较差;而AMQP是通用的协议标准,天然具有跨平台、跨语言的特性。

参考

  1. AMQP
  2. Message queue wiki
  3. What is message queueing?
  4. Advanced Message Queuing Protocol wiki
  5. Choosing Your Messaging Protocol: AMQP, MQTT, or STOMP
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
一、消息处理中的主要概念 “消息”是在两台计算机间传送的数据单位。消息可以非常简单,例如只包含文本字符串;也可以更复杂,可能包含嵌入对象。 消息被发送到队列中。“消息队列”是在消息的传输过程中保存消息的容器。消息队列管理器在将消息从它的源中继到它的目标时充当中间人。队列的主要目的是提供路由并保证消息的传递;如果发送消息时接收者不可用,消息队列会保留消息,直到可以成功地传递它。 “消息队列”是 Microsoft 的消息处理技术,它在任何安装了 Microsoft Windows 的计算机组合中,为任何应用程序提供消息处理和消息队列功能,无论这些计算机是否在同一个网络上或者是否同时联机。 “消息队列网络”是能够相互间来回发送消息的任何一组计算机。网络中的不同计算机在确保消息顺利处理的过程中扮演不同的角色。它们中有些提供路由信息以确定如何发送消息,有些保存整个网络的重要信息,而有些只是发送和接收消息。 “消息队列”安装期间,管理员确定哪些服务器可以互相通信,并设置特定服务器的特殊角色。构成此“消息队列”网络的计算机称为“站点”,它们之间通过“站点链接”相互连接。每个站点链接都有一个关联的“开销”,它由管理员确定,指示了经过此站点链接传递消息的频率。 “消息队列”管理员还在网络中设置一台或多台作为“路由服务器”的计算机。路由服务器查看各站点链接的开销,确定经过多个站点传递消息的最快和最有效的方法,以此决定如何传递消息。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值