【RPC】理解RPC

RPC是什么

remote procedure call(RPC):远程过程调用。

RPC就是像调用本地方法一样调用远程的过程。

过程是什么?
过程就是业务处理、计算任务,更直白理解,就是程序。

RPC采用CS结构,通过request-response消息模式实现。

  • RPC和RMI有什么区别
    RMI(remote method invocation)远程方法调用是oop领域中RPC的一种具体实现。
    我们可以在 jdk 中找到 java.rmi 包。

  • 我们熟悉的webservice、restful接口的调用是RPC吗
    在传统行业里大多会使用webservice,在各种手机应用程序和服务端交互的时候我们会使用restful的交互方式,这两种调用都是RPC。
    和RMI不同点仅仅是消息的组织方式、消息的协议不同,他们都是发起一个远端的调用,然后客户端拿到结果,但是在本地代码中没有体现是远程调用。

RPC不是什么新的事物,在19世纪六七十年代就已经出现了,在计算机出来有了网络之后就出现了RPC,RPC的叫法在1981年被首次提出。近些年来,因为分布式系统、服务化、微服务的兴起,RPC再次成为热点。

  • 远程过程调用较本地调用有何不同?
    速度相对慢
    可靠新减弱

RPC的流程

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

RPC流程中需要处理的问题

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

RPC协议是什么

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

RPC调用过程中采用的消息协议成为RPC协议。

RPC协议规定请求、响应消息的格式
在TCP上可选用火自定义消息协议来完成RPC消息交互
我们可以选用通用的标准协议(如:http、https),也可以根据自身的需要定义自己的消息协议!

在既有的协议上,为什么需要自己去定义自己的消息协议呢?
如果你觉得http协议能满足你的需要,就可以使用http协议;如果你觉得http太重了、太复杂了,就可以自己去定义。

常见的RPC协议

RPC框架是什么

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

Java领域:

  • 传统的webservice框架:Apache CXF、Apache Axis2、java自带的JAX-WS等。webservice框架大多基于标准的SOAP协议。
  • 新兴的微服务框架:Dubbo、Spring Cloud、Apache Thrift等。

为什么要用RPC

服务化:现在的互联网公司里面基本都会进行服务化、使用微服务架构
可重用:写的代码可以重用
系统间交互调用:传统企业系统与系统之间,有着交互获取数据的需要

PRC核心概念术语

  • Clien、Server、calls、replies、service、programs、procedures、version、marshalling(编组)、unmarshalling(解组)
  • 一个网络服务由一个或多个远程程序集构成
  • 一个远程程序实现一个或多个远程过程
  • 过程、过程的参数、结果在程序协议说明书中定义说明(协议说明书可以类比为接口文档)
  • 为兼容程序协议变更、一个服务端可能支持多个版本的远程程序
# 分布式 

评论

Your browser is out-of-date!

Update your browser to view this website correctly. Update my browser now

×