1. RPC 是什么
remote procedure call(RPC):远程过程调用。
过程:过程就是业务处理、计算任务,更直白理解,就是程序。(像调用本地方法一样调用远程的过程。)
RPC 采用 Client-Server 结构,通过 request-response 消息模式实现。
RPC 和 RMI 有什么区别?
- RMI(remote method invocation)远程方法调用是 oop 领域中 RPC 的一种具体实现。
我们熟悉的 webservice、restful 接口调用是 RPC 吗?
- 都是 RPC,仅消息的组织方式及消息协议不同。
远程过程调用较本地调用有何不同?
- 速度相对慢。
- 可靠性较弱。
2. RPC 流程
- 客户端处理过程中调用 Client stub(就像调用本地方法一样),传递参数;
- Client stub 将参数编组为消息,然后通过系统调用向服务端发送消息;
- 客户端本地操作系统将消息从客户端机器发送到服务端机器;
- 服务端操作系统将收到的数据包传递给 Server stub;
- Server stub 解组消息为参数。
- Server stub 再调用服务端的过程,过程执行结果以反方向的相同步骤响应给客户端。
RPC 流程中需要处理的问题
- Client stub、Server stub 的开发;
- 参数如何编组为消息,以及解组消息;
- 消息如何发送;
- 过程结果如何表示、异常情况如何处理;
- 如何实现安全的访问控制。
3. RPC 协议是什么?
RPC 调用过程中需要将参数编组为消息进行发送,接收方需要解组消息为参数,过程处理结果同样需要经编组、解组。消息由哪些部分构成及消息的表现形式就构成了消息协议。
RPC 调用过程中采用的消息协议称为 RPC 协议。
RPC 协议规定请求、响应消息的格式。 在 TCP(网络传输控制协议)上可选用或自定义消息协议来完成 RPC 消息交互。 我们可以选用通用的标准协议(如:http、https),也可根据自身的需要定义自己的消息协议。
4. 常见的 RPC 协议
5. RPC 框架是什么?
- 封装好参数编组、消息解组、底层网络通信的 RPC 程序开发框架,带来的便捷是可以直接在其基础上只需专注于过程代码编写。
- Java 领域:
- 传统的 webservice 框架:Apache CXF、Apache Axis2、java 自带的 JAX-WS 等等。webservice 框架大多基于标准的 SOAP 协议。
- 新兴的微服务框架:Dubbo、spring cloud、Apache Thrift 等等。
6. 为什么要用 RPC?
- 服务化
- 可重用
- 系统间交互调用
7. RPC 核心概念术语
- Client、Server、calls、replies、service、programs、procedures、version、marshalling(编组)、unmarshalling(解组)。
- 一个网络服务由一个或多个远程程序集构成。
- 一个远程程序实现一个或多个远程过程。
- 过程、过程的参数、结果在程序协议说明书中定义说明。
- 为兼容程序协议变更,一个服务端可能支持多个版本的远程程序。