gRPC 是一个高性能、通用的开源 RPC 框架,其由 Google 主要面向移动应用开发并基于 HTTP/2 协议标准而设计,基于 ProtoBuf (Protocol Buffers) 序列化协议开发,且支持众多开发语言()。
gRPC 提供了一种简单的方法来精确地定义服务和为iOS、Android 和 后台支持服务自动生成可靠性很强的客户端功能库。客户端充分利用高级流和链接功能,从而有助于节省带宽、降低的 TCP 链接次数、节省 CPU 使用、和电池寿命。下图为 gRPC 结构图:
- gRPC 默认通过 Protocol Buffers 来定义接口,可以制定更加严格规范的接口约束;
- 而基于 ProtoBuf 可以将数据序列化为二进制格式,从而大幅度减少数据量,进而大幅度的提升性能;
- 支持流式通信(Streaming),基于 HTTP/2 协议传输可以实现 Streaming 功能模式,可提供更快的响应和更高的性能;
- 支持多种语言,包括:Android Java、C++、C#/.NET、Dart、Go、Python、Web 等等;
gRPC Web是gRPC协议在浏览器端的javascript实现。
安装运行时所需的库命令
npm i grpc-web
首先定义协议文件xxxxxx.proto文件,格式如下
syntax = "proto3";
生成代码文件
protoc -I=$DIR business_server.proto \
如果你使用的是typescript,则执行
protoc -I=$DIR business_server.proto \
使用
引入生成的proto协议base类
import { BusinessClient } from "./protos/Business_serverServiceClientPb";
然后在你定义的api类里定义一个自己的类,这个类就可以调用里面的方法
constructor(hostname: string) {
调用Greeter方法
this.client.Greeter()