RPC和HTTP,它们之间到底啥关系

既然有 HTTP 请求,为什么还要用 RPC 调用?
gPRC 为什么使用 HTTP/2

Spring Cloud 默认是微服务通过Restful API来进行互相调用各自微服务的方法,同时也支持集成第三方RPC框架(这里的说的RPC是特指在一个应用中调用另一个应用的接口而实现的远程调用,即红色框所指的范围。)

Restful API底层采用HTTP作为通信协议
Spring Cloud 为了编码的方便(编程的优雅),使用了Feign。

Feign is a declarative web service client. It makes writing web service clients easier.

RPC(远程过程调用)是一个广泛应用的概念,它描述了一种通过网络从远程计算机程序上请求服务的机制,而不需要了解底层网络技术的细节。

RPC可以在不同的层次上实现,包括操作系统的进程间通信(IPC)和网络中不同主机间的服务调用。

RPC的实现通常遵循一种设计风格,即将函数或方法调用的参数和名称封装起来 ,然后通过网络发送到远程系统上执行。

这种设计风格与RESTful架构形成对比,后者通常使用HTTP作为传输协议,并且利用URI来表示资源,通过HTTP方法(如GET、POST、PUT、DELETE等)来表示操作,并且通常将参数通过查询字符串或请求体传递。

RPC框架也可以使用HTTP协议作为传输协议,比如grpc采用http 2.0作为传输协议

相关推荐
云登指纹浏览器5 小时前
静态IP和动态IP哪个好:跨境电商代理选型指南
网络·网络协议·tcp/ip
天天进步201510 小时前
Tunnelto 源码解析 #2:Rust Workspace 架构拆解:CLI、协议库与服务端如何分工
网络协议
Adellle10 小时前
开发一个简易的RPC框架
网络·网络协议·rpc
饮品爱好者11 小时前
[ 网络 ] NO.1 TCP/IP网络模型
网络·网络协议·tcp/ip
潜创微科技12 小时前
IT68051+IT6615:4K@60Hz HDMI+USB Over IP 网线延长方案|低延时 100 米无损传输
网络·网络协议·tcp/ip
2401_8734794013 小时前
【合规审计】如何记录每次IP查询用于监管报送?IP离线库日志集成操作指南
网络·网络协议·tcp/ip
Kurisu57514 小时前
深入拆解:从 TCP 状态机到 HTTP/3 拥塞控制的底层演进
网络协议·tcp/ip·http
蒸蛋一级爱好者15 小时前
UDP通信
网络·网络协议·udp
枕星而眠15 小时前
Linux网络协议三部曲:从UDP/TCP到HTTP,一篇打通任督二核
linux·网络协议·udp
剑神一笑15 小时前
Linux curl 命令深度解析:从 HTTP 请求到网络调试实战
linux·网络·http