初识gRPC

Posted F3nGaoXS

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了初识gRPC相关的知识,希望对你有一定的参考价值。

初识gRPC

1、认识RPC

RPC(Remote Procedure Call,远程过程调用)是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络细节的应用程序通信协议。RPC协议构建于TCP或UDP,或者是HTTP。允许开发者直接调用另一台服务器上的程序,而开发者无需另外的为这个调用过程编写网络通信相关代码,使得开发网络分布式程序在内的应用程序更加容易。

RPC采用客户端/服务器端的工作模式,请求服务即客户端,服务提供者即是服务器端。当执行一个远程过程调用时,客户端程序首先先发送一个带有参数的调用信息到服务端,然后等待服务端响应。在服务端,服务进程保持睡眠状态直到客户端的调用信息到达。当一个调用信息到达时,服务端获得进程参数,计算出结果,并向客户端发送应答信息。然后等待下一个调用。

并非狭义的客户端和服务器端,只要发送带有请求的调用信息就是客户端,而能够处理来自客户端的请求信息的就是服务器端。

rpc不是框架,是一种思想。

通常在一次RPC调用会有三个特点:

  • 约定好调用的语义(接口语法)
  • 约定好网络传输的内容的格式
  • 网络传输

RESTful就是目前比较常用的实现了RPC的架构风格,RESTful依靠HTTP/1.1和JSON来进行传输。

2、认识gRPC

gRPC是一个开源的、高性能的RPC框架。最初由google开发,现在是CNCF的一部分。其网络数据传输默认采用的是Google的Protobuf,并且使用HTTP/2。

3、gRPC工作流程

gRPC要求client存放一个stub(存根:提供与服务器相同的方法和功能),stub由gRPC框架自动生成。有了stub后,开发人员只需要关心具体的业务逻辑,而不需要关心网络通信相关实现原理。

client的stub是由protoc生成的,可以利用插件快速将proto文件生成gRPC需要的stub

4、gRPC的四种类型

  • unary(一元)

    客户端发送1个单一请求,服务端回复1个单一响应,和普通的HTTP API类似。

  • client streaming(客户端流)

    客户端发送多个消息流,并且期望服务端回复1个单一响应。

  • server streaming(服务端流)

    客户端仅发送1个单一请求,服务端回复多个消息流。

  • bidirectional streaming(双向流)

    客户端和服务端平行地发送和接受多条消息,并以任意顺序,非常灵活且无阻塞。

5、gRPC和REST的区别

以上是关于初识gRPC的主要内容,如果未能解决你的问题,请参考以下文章

存根的 gRPC 并发

Python 客户端在 GRPC 存根上返回 CERTIFICATE_VERIFY_FAILED

如何在 gRPC 服务器存根中从 ctx 创建 OpenTelemetry span

protoc 不生成服务存根文件

Golang 语言 gRPC 服务怎么同时支持 gRPC 和 HTTP 客户端调用?

Golang之gRPC初识