RPC 调用和 HTTP 调用的区别?
Posted 极牛科技
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了RPC 调用和 HTTP 调用的区别?相关的知识,希望对你有一定的参考价值。
很长时间以来都没有好好搞清楚 RPC(Remote Procedure Call) 和 HTTP 调用的区别,不都是写一个服务,然后在客户端调用么?
本文简单地介绍一下两种形式的 C/S 架构,先说一下他们最本质的区别,就是 RPC 主要是基于 TCP/IP 协议的,而 HTTP 服务主要是基于 HTTP 协议的,我们都知道 HTTP 协议是在传输层协议 TCP 之上的,所以效率来看的话,RPC 当然是要更胜一筹啦!下面来具体说一说 RPC 服务和 HTTP 服务。
第一层:应用层。定义了用于在网络中进行通信和传输数据的接口;
第二层:表示层。定义了不同的系统中数据的传输格式,编码和解码规范等;
第三层:会话层。管理用户的会话,控制用户间逻辑连接的建立和中断;
第四层:传输层。管理着网络中的端到端的数据传输;
第五层:网络层。定义网络设备间如何传输数据;
第六层:链路层。将上面的网络层的数据包封装成数据帧,便于物理层传输;
第七层:物理层。这一层主要就是传输这些二进制数据。
客户端(Client),服务的调用方。
服务端(Server),真正的服务提供者。
服务端存根(Server Stub),接收客户端发送过来的消息,将消息解包,并调用本地的方法。

-
gRPC 是 Google 最近公布的开源软件,基于最新的 HTTP2.0 协议,并支持常见的众多编程语言。我们知道 HTTP2.0 是基于二进制的 HTTP 协议升级版本,目前各大浏览器都在快马加鞭的加以支持。这个 RPC 框架是基于 HTTP 协议实现的,底层使用到了 Netty 框架的支持。 -
Thrift 是 Facebook 的一个开源项目,主要是一个跨语言的服务开发框架。它有一个代码生成器来对它所定义的 IDL 定义文件自动生成服务代码框架。用户只要在其之前进行二次开发就行,对于底层的 RPC 通讯等都是透明的。不过这个对于用户来说的话需要学习特定领域语言这个特性,还是有一定成本的。 -
Dubbo 是阿里集团开源的一个极为出名的 RPC 框架,在很多互联网公司和企业应用中广泛使用。协议和序列化框架都可以插拔式及其鲜明的特色。同样的远程接口是基于 Java Interface,并且依托于 spring 框架方便方便开发。可以方便的打包成单一文件,独立进程运行,和现在的微服务概念一致。
比如下面这个例子:POST http://www.httpexample.com/restful/buyer/info/shar
来源:blog.csdn.net/m0_38110132/article/details/81481454


各位程序员大佬们,请让我听到你们的声音!不管你是前端开发、后端研发、测试开发、移动端开发、全栈工程师、运维工程师、网络工程师、架构师、研发经理还是其他职位,不管你在做 android 开发 、ios 开发、U3D 、COCOS2DX、 自动化测试、功能测试、性能测试、白盒测试、灰盒测试、黑盒测试、ETL、数据仓库、数据开发、数据挖掘、数据分析、数据架构、算法研究、精准推荐、分布式、系统集成、地图引擎、人工智能、大数据、深度学习、机器学习、图像处理、图像识别、语音识别、语音学习、机器视觉、自然语言处理、视频开发、区块链还是其它技术支持。欢迎在评论中踊跃发表意见!


博客:niuzhendong.com
Github:github.com/niuzhendonglm
点个赞再走嘛!
以上是关于RPC 调用和 HTTP 调用的区别?的主要内容,如果未能解决你的问题,请参考以下文章