RPC主要是基于TCP/IP协议的,而HTTP服务主要是基于HTTP协议的,我们都知道HTTP协议是在传输层协议TCP之上的,所以效率来看的话,RPC当然是要更胜一筹啦!下面来具体说一说RPC服务和HTTP服务。
OSI网络七层模型
在说RPC和HTTP的区别之前,我觉的有必要了解一下OSI的七层网络结构模型(虽然实际应用中基本上都是五层),它可以分为以下几层:(从上到下)
-
第一层:应用层。定义了用于在网络中进行通信和传输数据的接口;
-
第二层:表示层。定义不同的系统中数据的传输格式,编码和解码规范等;
-
第三层:会话层。管理用户的会话,控制用户间逻辑连接的建立和中断;
-
第四层:传输层。管理着网络中的端到端的数据传输;
-
第五层:网络层。定义网络设备间如何传输数据;
-
第六层:链路层。将上面的网络层的数据包封装成数据帧,便于物理层传输;
-
第七层:物理层。这一层主要就是传输这些二进制数据。
实际应用过程中,五层协议结构里面是没有表示层和会话层的。应该说它们和应用层合并了。我们应该将重点放在应用层和传输层这两个层面。因为HTTP是应用层协议,而TCP是传输层协议。好,知道了网络的分层模型以后我们可以更好地理解为什么RPC服务相比HTTP服务要Nice一些!

RPC服务
从三个角度来介绍RPC服务:分别是RPC架构,同步异步调用以及流行的RPC框架。
RPC架构
先说说RPC服务的基本架构吧。允许我可耻地盗一幅图哈~我们可以很清楚地看到,一个完整的RPC架构里面包含了四个核心的组件,分别是Client ,Server,Clien

RPC基于TCP/IP,效率优于HTTP。RPC包括Client、Server、Client Stub和Server Stub四部分,适合大型企业,强调效率和解耦。HTTP简单直接,适合接口不多的小型企业。RPC的同步调用和异步调用提供了灵活的选择,流行的RPC框架有gRPC、Thrift和Dubbo。
最低0.47元/天 解锁文章
1664

被折叠的 条评论
为什么被折叠?



