一、RPC基本介绍
1、 RPC(RemoteProcedureCall)—远程过程调用,是一个计算机通信协议该协议允许运行于一台计算机的程序调用另一台计算机的子程序,而程序无需额外的为这个交互作用编程;
2、 两个或多个应用程序都分布在不同的服务器上,它们之间的调用都像是本地方法调用一样;
3、 常见的RPC框架有:比较知名的如阿里的Dubbo、google的gRPC、go语言的rpcx、Apache的thrift,Spring的SpringCloud(中的部分组件);
二、RPC调用流程
1、 RPC调用流程图;
2、 术语说明;
在RPC中,Client叫服务消费者,Server叫服务提供者。
3、 RPC调用流程说明;
1、服务消费方(client)以本地调用方式调用服务
2、client stub接收到调用后负责将方法、参数等封装成能够进行网络传输的消息体
3、client stub将消息进行编码并发送到服务端
4、server stub收到消息后进行解码
5、server stub根据解码结果调用本地的服务
6、本地服务执行并将结果返回给server stub
7、server stub将返回结果进行编码并发送至消费方
8、client stub接收消息并进行解码
9、服务消费方(client)得到结果
4、 小结;
RPC的目标就是将2-8这些步骤都封装起来,用户无需关心这些细节,可以像调用本地方法一样即可完成远程服务调用。