HTTP与RPC

一、概念

HTTP(Hypertext Transfer Protocol,超文本传输协议)是一种应用层协议,主要用于在Web服务器之间传输html页面和其他Web资源。

RPC(Remote Procedure Call,远程过程调用) 是一种通用的远程调用通信协议,它用于在不同的计算机之间执行执行远程方法的调用。该协议的目的是为了一个应用程序调用远程服务器上的方法时,就像调用本地方法一样方便,程序员无需做任何额外开发来保证调用的顺利完成。

二、通信方式

http是无状态的协议,使用的是请求-响应的模式,每次请求建立连接,响应结束则中断本次连接。客户端与服务端的通信其实是不可靠的,需要使用其它机制来保证数据的完整性与一致性。

RPC的通信是有状态的,客户端通过调用远程服务器上的方法来发送请求,服务器则会对该请求进行处理并返回相关数据。

三、数据传输

http通常使用JSON和XML等文本格式进行传输,这种方式具有良好的可读性和可扩展性,但是它比二进制数据的传输更慢,并且需要更多的带宽。

RPC则可以使用二进制数据传输,比如google的protobuf(Protocol Buffers)、Apache Thrift等。这些协议有更高的效率与更小的数据传输量,但可读性和可扩展性较差。

四、使用场景

http一般用于web应用,例如web应用服务器或浏览器,可使用各种语言来开发,RPC主要用于分布式应用和互联网应用中,其实高效可靠的特点,使其被广泛运用于云计算和大数据等领域。

五、使用中需要考虑

性能问题,如传输速度、使用的序列化工具、是否长连接、安全性等问题。http通常结合ssl/tls协议来确保安全性,RPC则通过数据加密与身份认证来确保通信安全。

相关推荐
惜.己1 天前
Jmeter中的断言(二)
测试工具·jmeter·1024程序员节
西电研梦2 天前
考研倒计时30天丨和西电一起向前!再向前!
人工智能·考研·1024程序员节·西电·西安电子科技大学
惜.己2 天前
Jmeter中的断言(四)
测试工具·jmeter·1024程序员节
·云扬·2 天前
Java IO 与 BIO、NIO、AIO 详解
java·开发语言·笔记·学习·nio·1024程序员节
网安_秋刀鱼2 天前
PHP代码审计 --MVC模型开发框架&rce示例
开发语言·web安全·网络安全·php·mvc·1024程序员节
HUODUNYUN2 天前
小程序免备案:快速部署与优化的全攻略
服务器·网络·web安全·小程序·1024程序员节
惜.己3 天前
Jmeter的后置处理器(二)
测试工具·github·1024程序员节
惜.己3 天前
Jmeter中的断言(一)
测试工具·jmeter·1024程序员节
cainiao0806053 天前
《物理学进展》
1024程序员节·核心期刊·知网期刊·职称评审
FFDUST3 天前
C++ —— string类(上)
c语言·开发语言·数据结构·c++·stl·1024程序员节