HTTP协议(Hyper Text Transfer Protocol),又叫做超文本传输协议。是一种用于在Web浏览器和Web服务器之间交换数据的应用层协议。通过HTTP,Web浏览器可以向Web服务器发送请求并获取响应,从而实现Web页面的访问和传输。HTTP使用TCP作为传输层协议,并采用请求-响应模型来进行通信。
RPC(Remote Procedure Call),又叫做远程过程调用,它允许客户端在不知道调用细节的情况下,调用存在于远程计算机上的某个对象,就像调用本地应用程序中的对象一样。RPC的调用协议通常包含传输协议和序列化协议。
RPC并不是一个具体的协议,而是一种调用方式,它并没有具体实现,只要按照 RPC 通信协议规范实现的框架,都属于RPC,比如 Dubbo、gRPC 等。
整体上看,HTTP和RPC的主要区别5点:
1.基于的通信协议不同,HTTP只能基于HTTP协议,而RPC可以基于HTTP、TCP和UDP协议。
2、调用方式不同,HTTP 接口通过 URL 进行调用,RPC 接口通过函数调用进行调用。
3、使用场景上不同,HTTP主要用于 B/S 架构,是万维网数据通信的基础,服务在网页端和服务端的数据传输上 。而 RPC 更多用于 C/S 架构,多用于分布式系统内部集群里,例如云计算、微服务架构、分布式数据库等,它可以在不同的服务之间进行远程调用,从而实现分布式系统的协作。
4、传输效率上,RPC使用自定义的TCP协议,请求报文体积更小,可以很好地减少报文体积,提高传输效率。而HTTP请求中会包含很多无用的内容。
5、性能上,RPC协议通常使用二进制编码来传输数据,相对于HTTP协议的文本传输,RPC具有更高的性能和效率。RPC协议通常采用高效的序列化和反序列化技术,减少了数据传输的大小和开销,提高了通信的速度和响应时间。