RPC技术

RPC是什么

remote procedure call:远程过程调用,过程是指业务处理、计算任务,更直白理解,就是程序。(像调用本地方法一样调用远程的过程。)RPC 采用Client-Server结构,通过request-response消息模式实现。

相关问题

  1. RPC 和RMI有什么区别

RMI(remote method invocation)远程方法调用是oop领域中RPC的一种具体事项。

  1. 我们熟悉的webservice、restfull接口调用是RPC吗?

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

  2. 远程过程调用较本地有何作用?

    速度性对慢

    可靠性较弱

RPC的流程

在这里插入图片描述

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

RPC协议是什么

RPC调用过程中需要将参数编组为消息进行发送,接收方需要解组消息为参数,过程处理结果同样需要经编组、解组。

**消息由哪些部分构成及消息的表示形成就构成了消息协议。**RPC调用过程中采用的消息协议称为RPC协议。

RPC 协议规定请求、响应消息的格式,

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

常见的RPC协议

XML-RPC is an RPC protocol that uses XML to encode its calls and Http as a transport mechanism.

JSON-RPC is an RPC protocol that uses JSON-encoded messages

SOAP is successor of XML-RPC and also uses XML to encode its HTTP-based call.

RPC 框架是什么

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

Java 领域:

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

新兴的微服务框架:Dubbo、Spring cloud、Apache Thrift等等。

为什么使用RPC

服务化

可重用

系统间交互调用

RPC 核心概念术语

  1. Client 、Server、calls、 replies、 service,programs,procedures,version,marshalling(编组)、unmarshalling(解组)
  2. 一个网络服务由一个多多个远程程序集构成
  3. 一个远程程序实现一个或多个远程过程
  4. 过程、过程的参数、结果在程序协议说明书中定义说明
  5. 为兼容程序协议变更、一个服务端可能支持多个版本的远程程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值