什么是RPC?

RPC (Remote Procedure Call)是远程过程调用,比如说现在有两台服务器A, B,一个在A服务器上的应用想要调用B服务器上的应用提供的某个,由于不在两个方法不在一个内存空间,不能直接调用,需要通过网络表达调用的语义和传达调用的数据。常存在于分布式系统中。

在分布式计算,远程过程调用(英语:Remote Procedure Call,缩写为 RPC)是一个计算机通信协议。该协议允许运行于一台计算机的程序调用另一个地址空间(通常为一个开放网络的一台计算机)的子程序,而程序员就像调用本地程序一样,无需额外地为这个交互作用编程(无需关注细节)。RPC是一种服务器-客户端(Client/Server)模式,经典实现是一个通过发送请求-接受回应进行信息交互的系统。

为何有http协议之后,还要RPC调用?

RPC跟HTTP不是对立面,RPC中可以使用HTTP作为通讯协议。RPC是一种设计、实现框架,通讯协议只是其中一部分。

RPC的本质是提供了一种轻量无感知的跨进程通信的方式,在分布式机器上调用其他方法与本地调用无异(远程调用的过程是透明的,你并不知道这个调用的方法是部署在哪里,通过PRC能够解耦服务)。RPC是根据语言的API来定义的,而不是基于网络的应用来定义的,调用更方便,协议私密更安全、内容更小效率更高。

RPC模式分为三层,①用户和服务器(负责处理业务逻辑,调用本地 Stub);②Stub处理客户端和服务端约定好的语法、语义的封装和解封装;③RPCRuntime负责最底层的网络传输。

简单的说, RPC 就是从一台机器 ( 客户端 ) 上通过参数传递的方式调用另一台机器 ( 服务器 ) 上的一个函数或方法 ( 可以统称为服务 ) 并得到返回的结果。

PRC架构组件

一个基本的RPC架构里面应该至少包含以下4个组件:

1 、客户端( Client ) : 服务调用方(服务消费者)
2 、客户端存根( Client Stub ) : 存放服务端地址信息,将客户端的请求参数数据信息打包成网络消 息,再通过网络传输发送给服务端
3 、服务端存根( Server Stub ) : 接收客户端发送过来的请求消息并进行解包,然后再调用本地服务进行处理
4 、服务端( Server ) : 服务的真正提供者

具体调用过程:
1 、服务消费者( client 客户端)通过调用本地服务的方式调用需要消费的服务;
2 、客户端存根( client stub )接收到调用请求后负责将方法、入参等信息序列化(组装)成能够进行网络传输的消息体;
3 、客户端存根( client stub )找到远程的服务地址,并且将消息通过网络发送给服务端;
4 、服务端存根( server stub )收到消息后进行解码(反序列化操作);
5 、服务端存根( server stub )根据解码结果调用本地的服务进行相关处理;
6 、本地服务执行具体业务逻辑并将处理结果返回给服务端存根( server stub );
7 、服务端存根( server stub )将返回结果重新打包成消息(序列化)并通过网络发送至消费方;
8 、客户端存根( client stub )接收到消息,并进行解码(反序列化);
9 、服务消费方得到最终结果;

而RPC框架的实现目标则是将上面的第2-10步完好地封装起来,也就是把调用、编码/解码的过程给封装起来,让 用户感觉上像调用本地服务一样的调用远程服务

RPC解决的三大问题 :

①协议约定问题(Stub) 指的是怎么规定远程调用的语法,怎么传参数等。用上面的类比,你怎么告诉你的朋友要玩什么游戏?是直接说游戏的名字,王者荣耀,绝地求生,还是说简称,王者,吃鸡,或者用 1 代表王者,2 代表吃鸡,只说 1 或 2。

②传输协议问题(RPCRuntime) 指的是在网络发生错误、重传、丢包或者有性能问题时怎么办?用上面的类比,你打电话时,刚说了打什么游戏,但是还没有收到对方回复,电话信号不好断了,这时候怎么处理?

③服务发现问题(插件比如:etcd) 指的是如何知道服务端有哪些服务可以调用,从哪个端口访问?服务端可能实现多个远程调用,在不同的进程上,随机监听端口,客户端要怎么才能知道这些端口呢?

什么是 GRPC?

gRPC 是谷歌开源的一个 RPC 框架,面向移动和 HTTP/2 设计,产自 Google,基于 ProtoBuf 序列化协议进行开发,支持多种语言(Golang、Python、Java等),本篇只介绍 Golang 的 gRPC 使用。因为 gRPC 对 HTTP/2 协议的支持使其在 Android、IOS 等客户端后端服务的开发领域具有良好的前景。gRPC 提供了一种简单的方法来定义服务,同时客户端可以充分利用 HTTP/2 stream 的特性,从而有助于节省带宽、降低 TCP 的连接次数、节省CPU的使用等。

  • 内容交换格式采用ProtoBuf(Google Protocol Buffers),开源已久,提供了一种灵活、高效、自动序列化结构数据的机制,作用与XML,Json类似,但使用二进制,(反)序列化速度快,压缩效率高。
  • 传输协议 采用http2,性能比http1.1好了很多

和很多RPC系统一样,服务端负责实现定义好的接口并处理客户端的请求,客户端根据接口描述直接调用需要的服务。客户端和服务端可以分别使用gPRC支持的不同语言实现。

 rpc是一种协议,grpc是基于rpc协议实现的一种框架。

grpc的解决rpc三大问题:

①协议约定。gRPC 的协议是 Protocol Buffers,是一种压缩率极高的序列化协议,Google 在 2008 年开源了 Protocol Buffers,支持多种编程语言,所以 gRPC 支持客户端与服务端可以用不同语言实现。

②传输协议。gRPC 的数据传输用的是 Netty Channel, Netty 是一个高效的基于异步 IO 的网络传输架构。Netty Channel 中,每个 gRPC 请求封装成 HTTP 2.0 的 Stream。

③服务发现。gRPC 本身没有提供服务发现的机制,需要通过其他组件。

简易理解

grpc是一种实现了rpc协议的框架,并且分别通过protocol buffer、netty channel 以及服务发现组件解决rpc的协议约定、传输协议、服务发现三大问题。

GPRC 和RPC 有什么区别?GPRC和RPC的区别是什么?相关推荐

  1. RPC 笔记(01)— RPC概念、调用流程、RPC 与 Restful API 区别

    1. 基本概念 PRC 远程过程调用 Remote Procedure Call,其就是一个节点请求另外一个节点提供的服务.当两个物理分离的子系统需要建立逻辑上的关联时,RPC 是牵线搭桥的常见技术手 ...

  2. spring cloud和普通rpc框架的区别

    spring cloud和普通rpc框架的区别 补了一部分,后续再补 背景 其实本文标题有点不对,Spring Cloud也是一种RPC框架,但是区别是它使用的是http协议的传输,整体技术和普通RP ...

  3. 一周一论文(翻译 总结)— [SOCC 14] DaRPC: Data Center RPC 基于RDMA的高性能通信RPC

    目录 Abstract 1. Introduction 2. Motivation 3. Background 4. Design of DaRPC 4.1 Single Client-Server ...

  4. 整合rpc远程调用_远程过程调用(RPC)

    分布式系统的主要特点是能够将一台机器上的一个任务分解到系统中其他的机器上运行,实现多个CPU的协同工作.远程过程调用RPC就是实现这一特点的有效方法之一 1.什么是RPC RPC的基本思想 (1984 ...

  5. c++socket多个客户端通过不同端口与一个服务端通信_手写RPC,深入底层理解整个RPC通信...

    一.前言 RPC,远程过程调用,调用远程方法像调用本地方法一样.RPC交互分为客户端和服务端,客户端调用服务端方法,服务端接收数据并打印到控制台,并response响应给客户端. RPC和HTTP的联 ...

  6. RPC入门总结(一)RPC定义和原理

    转载:深入浅出 RPC - 浅出篇 转载:RPC框架与Dubbo完整使用 转载:深入浅出 RPC - 深入篇 转载:远程调用服务(RPC)和消息队列(Message Queue)对比及其适用/不适用场 ...

  7. 【RPC框架、RPC框架必会的基本知识、手写一个RPC框架案例、优秀的RPC框架Dubbo、Dubbo和SpringCloud框架比较】

    一.RPC框架必会的基本知识 1.1 什么是RPC? RPC(Remote Procedure Call --远程过程调用),它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络的技术. ...

  8. 【RPC Dubbo】各大开源rpc 框架 比较(dubbo支持的各种协议)

    文章目录 1. 前言 2. 服务 2.1 为什么要做服务 2.2 服务带来的挑战 2.3 服务未来的趋势 3. 框架 3.1 服务框架对比 3.1.1 Dubbo 3.1.2 Dubbox 3.1.3 ...

  9. java基础巩固-宇宙第一AiYWM:为了维持生计,手写RPC~Version07(RPC原理、序列化框架们、网络协议框架们 、RPC 能帮助我们做什么呢、RPC异常排查:ctrl+F搜超时)整起

    上次Version06说到了咱们手写迷你版RPC的大体流程, 对咱们的迷你版RPC的大体流程再做几点补充: 为什么要封装网络协议,别人说封装好咱们就要封装?Java有这个特性那咱就要用?好像是这样.看 ...

  10. NET Core微服务之路:自己动手实现Rpc服务框架,基于DotEasy.Rpc服务框架的介绍和集成...

    原文:NET Core微服务之路:自己动手实现Rpc服务框架,基于DotEasy.Rpc服务框架的介绍和集成 本篇内容属于非实用性(拿来即用)介绍,如对框架设计没兴趣的朋友,请略过. 快一个月没有写博 ...

最新文章

  1. Golang的反射reflect深入理解和示例
  2. CommonJS规范(转)
  3. python基础学习中要懂的知识点:反射机制
  4. 学好机器学习,这里有想要的一切
  5. VDI序曲十五 配置 RemoteFX 以获得最佳体验
  6. 顺序存储结构和链式存储结构的优缺点
  7. C语言 数组指针 - C语言零基础入门教程
  8. 深度linux登录后界面卡死,Deepin Linux 15(.1)启动即卡死的问题
  9. Java 1.2.3 文件输入与输出
  10. 通过 ASP.NET 2.0 的数据增强功能来提高负载和减少代码 --作者:Dino Esposito
  11. Python基础——NaN(Not a Number)
  12. python有什么用-Python为什么这么火?学习python有什么用?
  13. CASS 10.1.6 安装教程
  14. 详解机器学习算法基础--K近邻算法
  15. linux库文件编译的makefile
  16. HP惠普服务器做RAID
  17. 去除input默认的加减号
  18. 导出数据提示--secure-file-priv选项问题的解决方法
  19. 队爷的讲学计划 (强连通缩点+最短路)
  20. 电脑的远程控制是什么

热门文章

  1. NTP服务端和客户端的部署——Chrony
  2. c语言标准化考试系统课程设计,c语言标准化考试系统课程设计
  3. 树莓派安装基于python的opencv
  4. Katago围棋学习记录(三)
  5. CDGP|保险行业如何做好数据治理?
  6. html中文档流概念+高度塌陷+bfc+浮动清除
  7. mysql use temporary_一次mysql 优化 (Using temporary ; Using filesort)
  8. 《系统化思维导论》读书心得
  9. attribute __naked cannot be compiled without allocated auto area
  10. bit, byte, short int占用的字节数简单解释