美文网首页
消息队列与RPC

消息队列与RPC

作者: Ahem_b908 | 来源:发表于2018-01-17 11:25 被阅读0次

消息队列特点:

1.Message Queue把请求的压力保存一下,逐渐释放出来,让处理者按照自己的节奏来处理。

2.Message Queue引入一下新的结点,让系统的可靠性会受Message Queue结点的影响。

3.Message Queue是异步单向的消息。发送消息设计成是不需要等待消息处理的完成。

所以对于有同步返回需求,用Message Queue则变得麻烦了。

RPC的特点:

1.同步调用,对于要等待返回结果/处理结果的场景,RPC是可以非常自然直觉的使用方式。

2. RPC也可以是异步调用。由于等待结果,Consumer(Client)会有线程消耗。如果以异步RPC的方式使用,Consumer(Client)线程消耗可以去掉。但不能做到像消息一样暂存消息/请求,压力会直接传导到服务Provider。

适用场合说明:

1.希望同步得到结果的场合,RPC合适。

2.希望使用简单,则RPC;RPC操作基于接口,使用简单,使用方式模拟本地调用。异步的方式编程比较复杂。

3.不希望发送端(RPC Consumer、Message Sender)受限于处理端(RPC Provider、Message Receiver)的速度时,使用Message Queue。

随着业务增长,有的处理端处理量会成为瓶颈,会进行同步调用到异步消息的改造。这样的改造实际上有调整业务的使用方式。比如原来一个操作页面提交后就下一个页面会看到处理结果;改造后异步消息后,下一个页面就会变成“操作已提交,完成后会得到通知”。

不适用场合说明:

RPC同步调用使用Message Queue来传输调用信息。 上面分析可以知道,这样的做法,发送端是在等待,同时占用一个中间点的资源。变得复杂了,但没有对等的收益。

对于返回值是void的调用,可以这样做,因为实际上这个调用业务上往往不需要同步得到处理结果的,只要保证会处理即可。(RPC的方式可以保证调用返回即处理完成,使用消息方式后这一点不能保证了。)

返回值是void的调用,使用消息,效果上是把消息的使用方式Wrap成了服务调用(服务调用使用方式成简单,基于业务接口)

原文连接:http://oldratlee.com/post/2013-02-01/synchronous-rpc-vs-asynchronous-message

相关文章

  • 消息队列与RPC

    消息队列特点: 1.Message Queue把请求的压力保存一下,逐渐释放出来,让处理者按照自己的节奏来处理。 ...

  • 第四章数据编码和更新-part4,designing Data-

    消息队列数据流 这部分会简要介绍一种异步消息传递系统,在某种意义上讲是在数据库和RPC的折中方案。他与RPC相似点...

  • Kafka原理总结

    MQ(消息队列)是跨进程通信的方式之一,可理解为异步rpc,上游系统对调用结果的态度往往是重要不紧急。使用消息队列...

  • springboot项目架构(4)activemq、rabbit

    消息队列实现 支持的消息队列 ActiveMq RabbitMq RocketMq Kafka 各个队列实现队列与...

  • RabbitMQ 入门

    rabbitMq 是消息中间件,常用作消息队列暂存,异步处理,发布/订阅也可以用作RPC调用(很少人使用),下面是...

  • 消息队列

    再介绍之前,先简短比较下RPC和消息队列。RPC大多属于请求-应答模式,也包括越来越多响应式范式,对于需要点对点交...

  • HIDL学习笔记之HIDL C++(第二天)

    快速消息队列 (FMQ) HIDL 的远程过程调用 (RPC) 基础架构使用 Binder 机制,这意味着调用涉及...

  • 消息队列概念与认知

    MQ学习系列: 消息队列概念与认知 ActiveMQ Topic消息重发 本文是-消息队列学习的概念与介绍篇。目的...

  • 消息队列概述

    一、什么是消息队列(WHAT ) 1.1 消息与消息队列 消息(Message)是指在应用间传送的数据。消息可以非...

  • Redis作为消息队列与RabbitMQ的比较

    Redis作为消息队列与RabbitMQ的比较 RabbitMQ RabbitMQ是实现AMQP(高级消息队列协议...

网友评论

      本文标题:消息队列与RPC

      本文链接:https://www.haomeiwen.com/subject/rniyoxtx.html