Golang语言实现gRPC的具体使用

目录

gRPC 的特点

使用 gRPC 定义服务端

使用 gRPC 的客户端

gRPC 是通信协议基于 HTTP/2,支持多语言的 RPC 框架,使用 Protobuf 作为它的接口设计语言(IDL),可以通过 protoc 工具生成 Golang 语言的结构体。

RPCRemote Procedure Call 的缩写,译为远程过程调用(也可译为远程方法调用或远程调用),它是计算机通信协议。该协议可以实现调用远程服务就像调用本地服务一样简单,无需关心跨网络,跨平台,跨语言等问题。

gRPC 消息序列化方式通常使用 Protobuf,它是二进制格式,体积小,网络传输快,占用带宽流量少,调用性能更高。

gRPC 的特点 IDL

gRPC 使用 ProtoBuf 来定义服务,ProtoBuf 是由 Google 开发的一种数据序列化协议(类似于 XMLJSON)。ProtoBuf 能够将数据进行序列化,并广泛应用在数据存储、通信协议等方面。多语言支持

gRPC 支持多种语言,并能够基于语言自动生成客户端和服务端功能库。目前已提供了 C 版本 grpcJava 版本 grpc-javaGo 版本 grpc-go,其中,grpc 支持 CC++Node.jsPythonRubyObjective-CPHPC# 等语言,grpc-java 已经支持 Android 开发。HTTP2

gRPC基于HTTP2标准设计,带来了更多强大功能,如双向流、头部压缩、多复用请求等。这些功能带来重大益处,如节省带宽、降低TCP链接次数、节省CPU使用和延长电池寿命等。同时,gRPC还能够提高了云端服务和Web应用的性能。gRPC既能够在客户端应用,也能够在服务器端应用,从而以透明的方式实现客户端和服务器端的通信和简化通信系统的构建。 使用 gRPC 定义服务端

gRPC 默认使用 Protobuf 作为接口设计语言,在 .proto 文件中使用 service 关键字定义服务,使用 rpc 和 returns 关键字定义指定请求参数和返回结果的方法。

gRPC 提供了 Protobuf 编译器插件 protoc-gen-grpc,用于编译 .proto 文件,生成服务端和客户端代码,我们只需在服务端编写实现 Api 的代码,然后在客户端调用 Api。

syntax = "proto3"; import "google/protobuf/any.proto"; package hello; option go_package = "proto/gen/go"; message HelloReq { string name = 1; } message HelloResp { int32 code = 1; string greet = 2; google.protobuf.Any details = 3; } service HelloService { rpc Greet(HelloReq) returns (HelloResp); } 使用 gRPC 的客户端

通过 protoc 命令编译 .proto 文件,自动生成服务端和客户端代码。

在服务端,手动编写生成的服务端方法的业务逻辑代码,然后运行 gRPC 服务,接收并处理客户端请求,gRPC 服务自动解码请求参数,然后执行服务的方法,并将返回结果自动进行编码。

在客户端,实现和服务相同的方法,然后客户端可以本地调用这些方法,将请求参数封装在 Protobuf 的消息类型中,gRPC 将请求发送给服务器,并返回服务器的 Protobuf 序列化方式的响应消息。

参考文章:

Golang 语言 gRPC 到底是什么?

gRPC简介

到此这篇关于Golang语言实现gRPC的具体使用的文章就介绍到这了,更多相关Golang gRPC内容请搜索易知道(ezd.cc)以前的文章或继续浏览下面的相关文章希望大家以后多多支持易知道(ezd.cc)!

推荐阅读

    golang代理怎么设置

    golang代理怎么设置,代理,请求,设置,语言,客户端,应用程序,Go语言(或称Golang)是一种广受欢迎的编程语言,尤其适用于网络编程。在创建Web应用程序

    什么是golang

    什么是golang,语言,执行,编程语言,机器语言,高级语言,运行,golang是一种静态强类型、编译型、并发型,并具有垃圾回收功能的编程语言;它可以在不损

    Golang之wait.Until 简单测试用例

    Golang之wait.Until 简单测试用例,结束,主程序,测试目的,验证wait.Until的用法 //测试wait.Until() 的用途package mainimport ( "fmt

    使用Golang实现简单Ping过程

    使用Golang实现简单Ping过程,报文,字节,摘要: Ping的基本原理是发送和接受ICMP请求回显报文,利用Go语言可以轻松实现这一过程,较之C/C++语言

    golang二进制读写文件-二进制文件

    golang二进制读写文件-二进制文件有些时候,我突然想知道MySQL的如何存储数据的.她是如何完整的获取某行的数据,并且获得每个字段的值.比如,我

    GoLang下载安装-bin文件安装

    GoLang下载安装-bin文件安装GoLang IDEA https://www.jetbrains.com/go/download/download-thanks.htmlgolang特性:Go原生支持并发(Concur

    Go gRPC服务proto数据验证进阶教程

    Go gRPC服务proto数据验证进阶教程目录前言创建proto文件,添加验证规则把grpc_validator验证拦截器添加到服务端其他类型验证规则设置总

    Go gRPC进阶教程服务超时设置

    Go gRPC进阶教程服务超时设置目录前言客户端请求设置超时时间服务端判断请求是否超时运行结果总结前言
    gRPC默认的请求的超时时间是很

    Go gRPC服务双向流式RPC教程

    Go gRPC服务双向流式RPC教程目录前言情景模拟新建proto文件创建Server端创建Client端总结前言
    上一篇介绍了客户端流式RPC,客户端不断的