白话理解什么是RPC

RPC是什么?

在这里插入图片描述
remote procedure call (RPC) :远程过程调用
远程字面好理解,这里讲下过程

什么是过程?

我们都知道存储过程,存储过程其实就是写好的一段代码放在数据库服务器上面,可以去调用触发它,它就可以执行完成一个动作;这就是过程

过程到底是什么呢?通俗点说过程其实就是业务处理计算任务、还不理解那你可以理解为它就是一段程序。调用方式就像调用本地方法一样,只不过是调用远程的过程(程序);远程过程调用就由我们RPC框架提供,所以对于我们应用代码 应用1(上面图流程) 调用不会去了解过程底层调用原理。

RPC 其实采用的是Client - Server结构,通过request - response消息模式实现。过程就是客户端想要调用时候发送请求(request)到我们的服务端,服务端处理完了之后响应(response)消息给客户端,也就是把结果返回给调用者。

RPC和RMI有什么区别?

RMI(remote method invocation)远程方法调用是oop领域中RPC的一种具体实现。
在这里插入图片描述

webservice、restfull接口调用是RPC吗?

都是RPC,仅消息的组织方式及消息协议不同。

RPC的流程

在这里插入图片描述

  1. 客户端处理过程中调用Client stub(就像调用本地方法一样),传递参数;
  2. Client stub将参数编组为消息,然后通过系统调用向服务端发送消息;
  3. 客户端本地操作系统将消息从客户端机器发送到服务端机器;
  4. 服务端操作系统将接收到的数据包传递给Server stub;
  5. Server stub 解组消息为参数;
  6. Server stub 再调用服务端的过程,过程执行结果以反方向的相同步骤响应给客户端;

流程中需要处理的问题

  1. Client stub、Server stub的开发;
  2. 参数如何编组为消息,以及解组消息;
  3. 消息如何发送;
  4. 过程结果如何表示、异常情况如何处理;
  5. 如何实现安全的访问控制;

RPC协议

RPC调用过程中需要将参数编组为消息进行发送,接收方需要解组消息为参数,过程处理结果同样需要经编组、解组;消息由哪些部分构成及消息的表示形式就构成了消息协议。

RPC协议规定请求、响应消息的格式;
在TCP(网络传输控制协议)上可选用或自定义消息协议来完成RPC消息交换;
我们可以选用通用的标准协议(如:http、https),也可根据自身的需要定义自己的消息协议。

常见的RPC协议

在这里插入图片描述

RPC框架是什么?

封装好参数编组、消息解组、底层网络通信的RPC程序开发框架,带来的便捷是可以直接在其基础上只需专注于过程代码编写。

传统的webservice框架:
Apache CXF、Apache Axis2、java自带的JAX-WS等等;webService框架大多基于标准的SOAP协议。

微服务框架:
Dubbo、spring cloud、Apache Thrift等等。

为什么要用RPC?

1、服务化

现在互联网公司系统架构都是微服务化;微服务框架都是RPC的框架。

2、可重用

代码可重用,做成服务化后大家可以各个地方调用。

3、系统间交互调用

多系统调用,比如多个厂商之间的通讯交互数据获取;比如传统webservice或微服务框架。

RPC相关术语

  • Client、Server、calls、replies、service、programs、procedures、version、marshalling(编组)、unmarshalling(解组)
  • 一个网络服务由一个或多个远程程序集构成;
  • 一个远程程序实现一个或多个远程过程;
  • 过程、过程的参数、结果在程序协议说明书中定义说明;
  • 为兼容程序协议变更、一个服务端可能支持多个版本的远程程序;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值