RPC和HTTP的区别

???

看了半天,还是没搞太透彻
https://blog.csdn.net/qq_16268979/article/details/122872208

这篇看后,感觉有点知道了
https://blog.csdn.net/Mr_YanMingXin/article/details/124653945

看完又懂了一点
https://zhuanlan.zhihu.com/p/540646115

这个需要自己总结下

在讲RPC的时候,讲到如下:
RPC类似于RMI(Remote Methods Invoke 远程方法调用,是JAVA中的概念,是JAVA十三大技术之一)。
J2EE的13种技术规范,也知之甚少
https://blog.csdn.net/qq_16268979/article/details/122991271

1 什么是RPC协议

1.1 简介
RPC即远程过程调用(Remote Procedure Call)

RPC协议是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。

1.2 原理及模型
RPC协议广泛的应用于分布式系统中,主要用于不同计算机(即服务节点)间的通信,RPC主要是基于Socket,而Socket又基于TCP,因此我们可以理解为RPC基于TCP协议(部分RPC框架基于HTTP协议),在TCP的基础上增加了编程语言的机制,比如反射、编码与解码、以及动态代理,因此我们可以认为RPC只是一个概念,而实现这一概念有不同方式,典型的RPC框架如gRPC、Thrift、Netty、Dubbo等都是基于这一思想。

RPC和HTTP的区别_第1张图片

2 什么是HTTP协议

2.1 简介
HTTP即超文本传输协议(Hyper Text Transfer Protocol)

HTTP是互联网上应用最为广泛的一种网络协议,是一个客户端和服务器端请求和应答的标准(TCP),用于从WWW服务器传输超文本到本地浏览器的传输协议,它可以使浏览器更加高效,使网络传输减少。

2.2 原理及模型

HTTP协议是处于OSI网络模型的最上层应用层的协议,基于TCP协议,是通信协议中相对简单的协议之一,为什么简单呢?我认为原因有二:一是封装了大量的协议和报文头,使用简单,二是明文传输,处理简单,也是基于此,HTTP协议成为了互联网中最广泛的协议之一。

RPC和HTTP的区别_第2张图片

3 为什么要拿HTTP和RPC协议进行比较?

为什么要拿HTTP和RPC进行比较呢,我觉得大抵是因为HTTP和RPC是互联网应用系统中使用最广泛的两种网络通信协议了吧,并且在使用上似乎谁都能替代谁(当然抛开使用效率层面),一个是简单易用,一个是复杂高效,因此二者间的比较会很丰富。

4 两者的相同点

都是基于TCP协议点对点通信
都可以在不同编程语言(应用系统)间进行通信

5 两者的不同点

所属网络七层模型中不同的网络层级(部分RPC框架属于应用层)
RPC和HTTP的区别_第3张图片
数据编码格式不同

一般情况下,RPC是长连接,HTTP则是短连接

一般情况下,RPC的传输效率高于HTTP

6 总结

在系统开发中,一般需要对外提供接口时,因为普适性,HTTP是首选;

而在同一个组织或公司内部进行不同系统间服务的提供时,面向服务封装的RPC更具有竞争力,可以针对服务进行可用性和效率的优化,

因此HTTP和RPC不同的网络通信协议各自具有更擅长的领域。

你可能感兴趣的:(rpc,网络协议,网络)