远程过程调用(RPC)

RPC是一种客户端/服务器模式的请求响应模型,简化了远程调用过程,隐藏了底层通信细节。调用流程包括客户端通过客户存根调用、消息编码、发送至服务端、服务存根解码、本地服务执行、结果返回并解码至客户端。关键在于消息的编码和解码机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值