golang使用最新grpc说明

1.环境说明

1.系统:ubuntu 版本20.04

2.软件:golang 版本1.15.6

2.所需文件

1.golang安装包 https://golang.org/dl/go1.15.6.linux-amd64.tar.gz

2.grpc包 https://github.com/grpc/grpc-go/archive/v1.34.0.tar.gz

3.protoc 文件 https://github.com/protocolbuffers/protobuf/releases/download/v3.14.0/protoc-3.14.0-linux-x86_64.zip

4.protobuf 文件 https://github.com/golang/protobuf/archive/v1.4.3.tar.gz

3.环境部署

1.golang环境安装

tar zxvf go1.15.6.linux-amd64.tar.gz-C/usr/local

2.设置环境变量

编辑编辑 /etc/profile 文件

nano /etc/profile

在文件末尾添加下列内容

exportGOROOT=/usr/local/go

exportGOBIN=$GOROOT/bin

exportPATH=$PATH:$GOBIN:$GOROOT

3.环境变量生效命令

source/etc/profile

4.验证安装是否成功命令

go version

输出goang版本 即为成功

5.开启 go mod

go env-wGO111MODULE=on

go env-wGOPROXY=https://goproxy.cn,https://goproxy.io,direct

6.下载依赖

gogetgoogle.golang.org/protobuf/cmd/protoc-gen-go \

        google.golang.org/grpc/cmd/protoc-gen-go-grpc

或者直接将grpc包和protobuf包解压到$GOPATH/google.golang.org

7.把protoc添加到环境变量中

exportPATH="$PATH:$(go env GOPATH)/bin"

或者直接解压protoc-3.14.0-linux-x86_64.zip ,将bin目录的protoc复制到$GOBIN目录

8.运行helloword example

cd $GOPATH/google.golang.org/grpc/example/helloworld

$ gorun greeter_server/main.go

重新打开一个新端口,运行

$ gorun greeter_client/main.go

Greeting: Hello world

9.修改proto内容,重新编译

protoc--go_out=.--go_opt=paths=source_relative \

--go-grpc_out=.--go-grpc_opt=paths=source_relative \

   helloworld/helloworld.proto

10. go_package 说明

.proto文件应包含一个选项,用于指定包含所生成代码的Go软件包的完整导入路径。

option go_package="example.com/foo/bar";

输出文件所在的输出目录的子目录取决于go_package选项和编译器标志:

默认情况下,输出文件放置在以Go软件包的导入路径命名的目录中。例如,protos/foo.proto 具有上述go_package选项的文件将生成名为的文件 example.com/foo/bar/foo.pb.go。

如果给--go_opt=module=$PREFIX标记protoc,则从输出文件名中删除指定的目录前缀。例如,protos/foo.proto具有上述go_package选项和标志--go_opt=module=example.com/foo的文件将生成名为的文件 bar/foo.pb.go。

如果给--go_opt=paths=source_relative标记 protoc,则将输出文件放置在与输入文件相同的相对目录中。例如,该文件protos/foo.proto 生成名为的文件protos/foo.pb.go。

当您像这样运行原型编译器时

protoc--proto_path=src--go_out=build / gen--go_opt=paths=source_relative src / foo.proto src / bar / baz.proto

源.proto文件应包含一个go_package选项,用于为包含该文件的包指定完整的Go导入路径。如果没有 go_package选择,编译器将尝试猜测一个。编译器的未来版本将使该go_package选项成为必需。

生成代码的Go软件包名称将是该go_package选项的最后一个路径部分 。例如:

// Go程序包名称为“ timestamppb”。

选项go_package=“ google.golang.org/protobuf/types/known/timestamppb”;

导入路径用于确定一个.proto文件导入另一.proto文件时必须生成哪些导入语句 。例如,如果是 a.protoimport b.proto,则生成的a.pb.go文件需要导入包含生成的b.pb.go文件的Go软件包(除非两个文件都在同一个软件包中)。

导入路径还用于构造输出文件名。有关详细信息,请参见上面的“编译器调用”部分。

该go_package选项还可以包括一个显式的程序包名称,该名称与导入路径之间用分号分隔。例如:“ example.com/foo;package_name”。不鼓励使用此方法,因为通常使包名称与导入路径相对应(默认值)更加清晰。作为该go_package选项 的替代方法,.proto可以在命令行中使用 --go_opt=M=$FILENAME=$IMPORT_PATH flag to protoc.

具体protoc语法详情见链接 https://developers.google.com/protocol-buffers/docs/reference/go-generated#package

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容