- RPC是什么?
RPC是远程过程调用(Remote Procedure Call )的缩写。就是一台服务器上的服务通过参数传递的方式调用另一台服务器
的服务,并获取返回结果。
比如有两台服务器A、B,A上的服务想要调用B上的函数或方法,由于不在同一个内存空间,不能直接调用,需要通过网络来表达调用的语义和传达调用的数据。
- RPC采用客户端/服务器(C/S)模式,是一个请求响应模型,客户端发起请求,服务端返回响应,类似于http的工作方式
- RPC会隐藏底层的通讯细节,不需要直接处理Socket通讯或HTTP通讯
- RPC使程序以本地调用的方式进行远程过程调用
- 远程过程调用流程:
- 客户端(client)以正常方式调用client stub(客户存根);
- client stub接收到调用后,将方法、参数等组装成能够进行网络传输的消息体(编码);
- client stub找到服务地址,并将消息发送到服务端;
- server stub(服务存根)收到消息后进行解码,然后根据解码结果调用本地服务;
- 本地服务执行并将结果返回给server stub;
- server stub将结果打包成消息(编码)并发送至消费方;
- client stub接收消息并进行解码;
- 客户端最终得到结果。
- 怎么对消息进行编码和解码?