Go语言学习路

初始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带来了更多强大功能,如双向流,头部压缩,多服用请求等。
上一篇下一篇

猜你喜欢

热点阅读