083. RPC 技术简介

Wesley13
• 阅读 541

1. RPC 是什么


083. RPC 技术简介

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

  • 过程:过程就是业务处理、计算任务,更直白理解,就是程序。(像调用本地方法一样调用远程的过程。)

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

  • RPC 和 RMI 有什么区别?

    • RMI(remote method invocation)远程方法调用是 oop 领域中 RPC 的一种具体实现。
  • 我们熟悉的 webservice、restful 接口调用是 RPC 吗?

    • 都是 RPC,仅消息的组织方式及消息协议不同。
  • 远程过程调用较本地调用有何不同?

    • 速度相对慢。
    • 可靠性较弱。

2. RPC 流程


083. RPC 技术简介

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

RPC 流程中需要处理的问题

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

3. RPC 协议是什么?


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

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

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

4. 常见的 RPC 协议


https://en.wikipedia.org/wiki/Remote_procedure_call

083. 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(解组)。
  • 一个网络服务由一个或多个远程程序集构成。
  • 一个远程程序实现一个或多个远程过程。
  • 过程、过程的参数、结果在程序协议说明书中定义说明。
  • 为兼容程序协议变更,一个服务端可能支持多个版本的远程程序。
点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Easter79 Easter79
2年前
swap空间的增减方法
(1)增大swap空间去激活swap交换区:swapoff v /dev/vg00/lvswap扩展交换lv:lvextend L 10G /dev/vg00/lvswap重新生成swap交换区:mkswap /dev/vg00/lvswap激活新生成的交换区:swapon v /dev/vg00/lvswap
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
ES6 新增的数组的方法
给定一个数组letlist\//wu:武力zhi:智力{id:1,name:'张飞',wu:97,zhi:10},{id:2,name:'诸葛亮',wu:55,zhi:99},{id:3,name:'赵云',wu:97,zhi:66},{id:4,na
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这