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等都是基于这一思想。
2 什么是HTTP协议
2.1 简介
这是老生常谈的协议了 too,HTTP即超文本传输协议(Hyper Text Transfer Protocol)
HTTP是互联网上应用最为广泛的一种网络协议,是一个客户端和服务器端请求和应答的标准(TCP),用于从WWW服务器传输超文本到本地浏览器的传输协议,它可以使浏览器更加高效,使网络传输减少。
2.2 原理及模型
HTTP协议是处于OSI网络模型的最上层应用层的协议,基于TCP协议,是通信协议中相对简单的协议之一,为什么简单呢?我认为原因有二:一是封装了大量的协议和报文头,使用简单,二是明文传输,处理简单,也是基于此,HTTP协议成为了互联网中最广泛的协议之一。
为什么要拿HTTP和RPC进行比较呢,我觉得大抵是因为HTTP和RPC是互联网应用系统中使用最广泛的两种网络通信协议了吧(模仿下鲁迅),并且在使用上似乎谁都能替代谁(当然抛开使用效率层面),一个是简单易用,一个是复杂高效,因此二者间的比较会很丰富。
4 两者的相同点
- 都是基于TCP协议点对点通信
- 都可以在不同编程语言(应用系统)间进行通信
5 两者的不同点
- 所属网络七层模型中不同的网络层级(部分RPC框架属于应用层)
- 数据编码格式不同
- 一般情况下,RPC是长连接,HTTP则是短连接
- 一般情况下,RPC的传输效率高于HTTP
6 总结
在系统开发中,一般需要对外提供接口时,因为普适性,HTTP是首选,而在同一个组织或公司内部进行不同系统间服务的提供时,面向服务封装的RPC更具有竞争力,可以针对服务进行可用性和效率的优化,因此HTTP和RPC不同的网络通信协议各自具有更擅长的领域。