赞
踩
MQ全称是Message Queue,直译过来叫做消息队列。MQ本质上是一个队列,遵循先进先出的原则,而队列存放内容为message,主要是作为分布式应用之间实现异步通信的方式。是一种跨进程的通信机制,用于上下游传递消息。
它具有低耦合、可靠投递、广播、流量控制、最终一致性等一系列功能,成为异步RPC的主要手段之一。现在主流的消息队列有:ActiveMQ、RabbitMQ,Kafka,RocketMQ等。
流量消峰:当流量超过处理上限时,正常情况下,超过上限的流量不做处理。而MQ可以把多出来的一部分流量放入消息队列做缓冲。
举个例子:假设某订单系统每秒最多能处理一万次订单,也就是最多承受的10000qps,正常情况下,下单一秒后就能返回结果。但是在高峰期,如果有两万次下单操作,系统是处理不了的,只能限制订单超过一万后不允许用户下单。如果使用消息队列做缓冲,则可以取消这个限制,把一秒内下的订单分散成一段时间来处理,这时有些用户还可以下单但是可能会在十几秒后才能收到下单成功的操作,返回结果会有一段时间的延迟但是仍可以进行下单操作。
以电商应用为例,应用中有订单系统、库存系统、物流系统、支付系统。
耦合:用户创建订单后,如果耦合调用库存系统、物流系统、支付系统,任何一个子系统出了故障,都会造成下单操作异常。
加入MQ后:当转变成基于消息队列的方式后,系统间调用的问题会减少很多,比如物流系统因为发生故障,需要几分钟来修复。在这几分钟的时间里,物流系统要处理的内存被缓存在消息队列中,用户的下单操作可以正常完成。当物流系统恢复后,继续处理订单信息即可,中单用户感受不到物流系统的故障,提升系统的可用性。
有些服务间调用是异步的,例如 A 调用 B,B 需要花费很长时间执行,但是 A 需要知道 B 什么时候可以执行完,以前一般有两种方式:1)A 过一段时间去调用 B 的查询 api 查询;2)A 提供一个 callback api, B 执行完之后调用 api 通知 A 服务。
以上两种方式都不是很优雅,使用消息队列,可以很方便解决这个问题:A 调用 B 服务后,只需要监听 B 处理完成的消息,当 B 处理完成后,会发送一条消息给 MQ,MQ 会将此消息转发给 A 服务。这样 A 服务既不用循环调用 B 的查询 api,也不用提供 callback api。同样B 服务也不用做这些操作,A 服务还能及时的得到异步处理成功的消息。
MQ支持发布订阅机制。支持上下游的一对一、一对多、或者广播模式,并且都可以根据规则选择分发的对象。这样一份上游数据,众多下游系统中,可以根据规则来选择是否接收这些数据。
事务 Transaction:是一种特殊的执行程序,一般具有四个特性:
分布式事务:是指事务的参与者、支持事务的服务器、资源服务器以及事务管理器分别位于不同的分布式系统的不同节点之上。例如在大型电商系统中,下单接口通常会扣减库存、减去优惠、生成订单 id, 而订单服务与库存、优惠、订单 id 都是不同的服务,下单接口的成功与否,不仅取决于本地的 db 操作,而且依赖第三方系统的结果,这时候分布式事务就保证这些操作要么全部成功,要么全部失败。本质上来说,分布式事务就是为了保证不同数据库的数据一致性。
例如:一个用户下单的整个流程,MQ在这其中保证的作用:
生产者的逻辑
消费者的逻辑
消息中间件带来诸多好处的同时,也会引入很多的弊端:
队理管理器(queue mr),是MQ系统当中最上层的一个管理器,由它为我们提供基于队列的消息服务
消息(messages):在MQ中,把应用程序交由MQ传输的数据,某个应用向应用程序发出的请求处理等都可以称做消息。消息又包括两部分:
队列(queue):存放消息的地方,队列中的消息直到被应用程序消费之后再结束消息的生命周期。队列又可分为多种类型:
通道:MQ系统中队列管理器之间传递消息的管道
MQ可以在内存或者磁盘上,队列中存储消息直到被应用程序读取。应用程序可以通过MQ独立的执行,不需要彼此之间有其他联系,也不需要等待接收程序接收此消息。在分布式计算环境中,为了集成分布式应用,开发者需要对异构网络环境下的分布式应用提供有效的通信手段。为了管理需要共享的信息,对应用提供公共的信息交换机制是重要的。常见的有以下几种:
之前了解到,MQ是一种常用的异步通信机制。它可以帮助系统的不同组件在无需直接相互通信的情况下,实现数据的传输和处理。消息队列的核心概念之一是消息分发策略(Message Dispatching Strategy),它决定了在发送方发送消息到消息队列后,消息如何被接收方从队列中取出并处理。
消息分发策略是指消息在队列中如何被分配给接收方的规则。常见的消息分发策略有以下几种:
AMQP协议(Advanced Message Queuing Protocol—高级消息队列协议),一个提供统一消息服务的应用层标准高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同开发语言等条件的限制。
特点:分布式事务支持、消息的持久化支持、高性能和高可靠的消息处理优势
应用:RabbitMQ、ActiveMQ
MQTT(Message Queuing Telemetry Transport,消息队列遥测传输协议),是一种基于发布/订阅(publish/subscribe)模式的“轻量级”通讯协议,该协议构建于TCP/IP协议上,由IBM在1999年发布。
特点:以极少的代码和有限的带宽,为连接远程设备提供实时可靠的消息服务;轻量、结构简单、传输快、不支持事务、没有持久化设计
应用:在物联网、小型设备、移动应用等方面有较广泛的应用,RabbitMQ通过插件可以支持该协议
OpenMessage协议是由阿里、雅虎和滴滴出行、 Stremalio等公司共同参与创立的分布式消息中间件、流处理等领域的应用开发标准。
特点:结构简单,解析速度快,支持事务和持久化设计
Kafaka协议,基于TCP/IP的二进制协议。消息内部是通过长度来分割,由些基本数据类型组成。
特点:结构简单、解析速度快、无事务支持、有持久化设计
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。