高并发架构系列:详解RPC远程调用和消息队列MQ的区别

作者 : 开心源码 本文共1113个字,预计阅读时间需要3分钟 发布时间: 2022-05-12 共187人阅读

RPC

RPC(Remote Procedure Call)远程过程调用,主要处理远程通信间的问题,不需要理解底层网络的通信机制。

RPC框架

知名度较高的有Thrift(FB的)、dubbo(阿里的)。

RPC的一般需要经历4个步骤:

1、建立通信

首先要处理通讯的问题:即A机器想要调用B机器,首先得建立起通信连接,主要是通过在用户端和服务器之间建立TCP连接。

2、服务寻址

要处理寻址的问题,A服务器上如何连接到B服务器(如主机或者IP地址)以及特定的端口,方法的名称是什么。

3、网络传输

1)序列化

当A服务器上的应用发起一个RPC调用时,调用方法和参数数据都需要先进行序列化。

2)反序列化

当B服务器接收到A服务器的请求之后,又需要对接收到的参数等信息进行反序列化操作。

4、服务调用

B服务器进行本地调用(通过代理商Proxy)之后得到了返回值,此时还需要再把返回值发送回A服务器,同样也需要经过序列化操作,而后再经过网络传输将二进制数据发送回A服务器。

通常,一次完整的PRC调用需要经历如上4个步骤。

更加详细的RPC详情,点击参考:高并发架构系列:RPC框架的实现原理,调用全过程,及RPC架构组件

MQ(消息队列)

消息队列(MQ)是一种能实现生产者到消费者单向通信的通信模型,一般来说是指实现这个模型的中间件。

典型的MQ中间件:

RabbitMQ、ActiveMQ、Kafka等

典型的特点:

1、解耦

2、可靠投递

3、广播

4、最终一致性

5、流量削峰

6、消息投递保证

7、异步通信(支持同步)

8、提高系统吞吐、健壮性

典型的使用场景:

秒杀业务中利用MQ来实现流量削峰,以及应用解耦使用。

RPC和MQ的区别和关联:

1.在架构上,RPC和MQ的差异点是,Message有一个中间结点Message Queue,可以把消息存储。

2.同步调用:对于要立即等待返回解决结果的场景,RPC是首选。

3.MQ 的使用,一方面是基于性能的考虑,比方服务端不能快速的响应用户端(或者用户端也不要求实时响应),需要在队列里缓存。

另外一方面,它更侧重数据的传输,因而方式更加多样化,除了点对点外,还有订阅发布等功能。

4.而且随着业务增长,有的解决端解决量会成为瓶颈,会进行同步调用改造为异步调用,这个时候可以考虑使用MQ。

详细的MQ消息队列的选型比较,点击参考:阿里P8架构师谈:主流的消息队列MQ比较,详解MQ的4类应用场景

以上是就是RPC和MQ消息队列的区别详情,觉得有用请点赞支持,送你[架构学习资料包]

资料包内容:

1、最新最全的架构师学习图谱高清版:架构师知识点一目了然;

2、架构师学习专题88期资料合集:配合图谱,学习更科学;

3、程序员高赞的架构师学习图9本(电子书)。

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » 高并发架构系列:详解RPC远程调用和消息队列MQ的区别

发表回复