初始gRPC
2021-08-26 本文已影响0人
TZX_0710
gRPC由google开发,是一款语言中立、平台中立、开源的远程过程调用系统
gRPC客户端和服务端可以在多种环境中运行和交互。
gRPC与Protobuf介绍
- 微服务架构中,由于每个服务对应的代码库是独立运行的,无法直接调用,彼此间的通信就是个大问题
- gRPC可以实现微服务,将大的项目拆分为多个小且独立的业务模块,也就是服务,各服务间使用搞笑的protobuf协议进行RPC调用。gRPC默认使用protocol buffers 。
- 可以用proto files创建gRPC服务,用message类型来定义方法参数和返回类型
gRPC和Protobuf安装
go get github.com/golang/protobuf/proto go get google.golang.org/grpc go get github.com/golang/protobuf/protoc-gen-go
gRPC简介
gRPC是一个高性能、开源、通用的RPC框架,基于HTTP2协议标准设计开发,默认采用
Protocol Bufferes
数据序列化协议,支持多种开发语言。gRPC提供了一种简单的方法来精确的定义服务,并且为客户端和服务端自动生成可靠的功能库。在gRPC客户端可以直接调用不同服务器上的远程程序,使用姿势看起来就像调用本地程序一样,很容易去构建分布式应用和服务
主要特性
- 强大的IDL
- gRPC使用ProtoBuf来定义服务,ProtoBuf是由Google开发的一种数据序列化协议。ProtoBuf能够将数据进行序列化,并广泛应用在数据存储、通信协议等方面
- 多语言支持
- gRPC支持多种语言,并能够基于语言自动生成客户端和服务端功能库
- HTTP2
- gRPC基于HTTP2标准设计,所以想对于其他RPC框架,gRPC带来了更多强大功能,如双向流,头部压缩,多服用请求等。