为什么需要RPC

写在前面

在工作中经常会用到RPC的框架,比如dubbo,grpc等。但不知道你想过没有,为什么我们需要rpc,有socket不就够了嘛?这其实也是我一直以来的一个疑惑,带着这个疑问一起来看下本文吧!

1:正文

正常,两个独立的应用程序想要通信,只能通过socket编程的方式,但是socket编程其实是有门槛的,而且如果是要考虑到性能问题,容错等情况的话,程序将会更加复杂,门槛将会更高,所以可以说socket编程的门槛就是我们需要RPC的原因之一了。还有其他原因嘛?有的,交互协议的设计就是其中之一,什么意思呢?比如服务端提供了加法和乘法功能,则我们就需要定义一种数据格式,比如如下吧:

复制代码
{
    "type": "1", // 1加法,2乘法
    "param1": "333",
    "param2": "222" 
}

不管是服务端开发还是客户端开发都需要严格按照这个规范来开发,会明显增加编码的复杂度(潜在的问题更多),和测试的复杂度,当然如果功能更加复杂的话协议设计本身也不简单😀😀😀。

为了解决以上这些问题,大牛Bruce Jay Nelson 写了一篇论文Implementing Remote Procedure Calls,为以上的问题给出了一个完美的解决方案,这就是RPC了(所以,RPC也是有规范的),整个通信的过程如下图:

有了这个规范之后,我们就能能够像调用本地的方法一样,调用远端服务的功能了。

写在后面

参考文章列表

相关推荐
70asunflower3 小时前
Python网络内容下载框架教程
开发语言·网络·python
科技块儿3 小时前
平台需展示用户IP属地,如何操作?
网络·网络协议·tcp/ip
..过云雨3 小时前
数据链路层核心全解:以太网、MAC 地址、MTU 与 ARP 协议深度剖析
网络·网络协议·tcp/ip·计算机网络
NaclarbCSDN3 小时前
OSI模型与TCP/IP模型
网络·网络协议·tcp/ip
RisunJan3 小时前
Linux命令-lnstat(显示 Linux 网络统计信息)
linux·运维·网络
一路往蓝-Anbo3 小时前
第 4 篇:策略模式 (Strategy) —— 算法的热插拔艺术
网络·驱动开发·stm32·嵌入式硬件·算法·系统架构·策略模式
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.3 小时前
Keepalived高可用配置指南
服务器·网络·php
2401_832298104 小时前
腾讯云第九代CVM,玄灵网卡加持重构算力新范式
网络
Cloud Traveler4 小时前
Archcraft携手cpolar打造轻量化远程开发环境
网络·云原生·eureka
七夜zippoe4 小时前
网络安全实战:从TLS/SSL到JWT与OAuth2.0的完整防御体系构建
网络·安全·web安全·ssl·tls