go mod 写grpc服务

简介: 本文为go mod 简单搭建grpc服务demo实践。也记录了其中的一些官方未交待的坑。

本文为go mod 简单搭建grpc服务demo实践。也记录了其中的一些官方未交待的坑。
总结步骤:

1、下载依赖包gRPC。主要关注底下的protobuf和protol-gen-go包,用于处理协议文件的。

2、下载protoc.exe执行文件,将bin目录配置到环境变量。该文件主要用于执行对.proto协议文件转为.pb.go对应语言文件。

3、安装插件protol-gen-go生成.exe可执行文件(可在依赖包对应目录下直接执行命令生成exe后拷贝出去),放入环境变量中,如刚刚设置的bin目录。

4、项目目录中编写如Hi.proto文件,并cmd进入该目录执行protoc --go_out=plugins=grpc:. Hi.proto命令,将在文件指定的包下生成Hi.pb.go文件(grpc接口协议文件代码)。

5、编写服务端实现协议文件中的结构体接口,客户端调用。

下来就来详细介绍。

一、下载依赖包gRPC

IDE创建项目目录grpcDemo,并配置代理。
image.png

然后我们下载依赖包就简单了,直接在项目目录下创建go.mod文件,如下:
image.png

然后基本的main.go里面写mian函数,执行命令go mod init。等待下载完,如下:
image.png

依赖包我们下完了。

我们打开看一下,能看到这个,
image.png

我们要的就是这两个插件,但是这还不算装完,因为protoc-gen-go并没有安装生成exe 文件,这个我们后面再讲。

github.com/golang/protobuf

github.com/golang/protobuf/protoc-gen-go

二、下载protoc.exe执行文件,将bin目录配置到环境变量

这个要自己额外地去下,地址看这里。下载解压将看到如下目录。protoc.exe文件就在bin文件夹下,把bin目录配置到环境变量。可以cmd下执行protoc --version看看是不是装好了。

image.png

该文件主要用于执行对.proto协议文件转为.pb.go对应语言文件。当然我们前面还讲到,这样还是不够的,还需要一个插件。

三、安装插件protol-gen-go生成.exe可执行文件

可在依赖包对应目录下直接执行go build命令生成exe后拷贝出去,放入环境变量中,如刚刚设置的bin目录和protoc.exe文件放一起(这里为图方便),当然也可以自行存在路径,然后把路径配置到环境变量即可。

image.png
image.png

四、编写如Hi.proto协议文件,并用命令转成对应语言(协议)文件

上面,我们把插件的工具都准备好了,意味着我们可以执行命令来处理协议文件了。

在项目目录中编写如Hi.proto文件,并cmd进入该目录执行protoc --go_out=plugins=grpc:. Hi.proto命令(注意这里IDE直接执行这个命令是不行的),将在文件指定的包下生成Hi.pb.go文件(grpc接口协议文件代码)。 这里的--go_out 必须protol-gen-go.exe的支持。

image.png

image.png

这里指定的包名就是将生成协议文件的文件夹。执行完命令后看到的文件:
image.png

五、编写服务端代码

实现协议中的接口,提供逻辑服务。

image.png

main文件自然必不可少。
image.png

我们启动服务端,监听8081端口。这里需要注意,如果直接run go build main.go有可能不成功。go build 整个项目倒是每次都成功的。
image.png

六、编写客户端

客户端和服务端也一样的先创建项目,go mod grpc依赖包。只是客户端可以直接使用.pd.go文件,所以不用处理协议生成这个动作(装插件和写.proto文件后命名转换)。直接拷贝Hi.pb.go文件,然后实现客户端的调用代码即可。其他注意点同上(必须go build 整个项目)。然后我们启动客户端就可以看到服务端的应答了。
image.png

好了,一个GRPC服务就写好了。
image.png

前端使用grpc

相关文章
|
2月前
|
监控 算法 Go
Golang深入浅出之-Go语言中的服务熔断、降级与限流策略
【5月更文挑战第4天】本文探讨了分布式系统中保障稳定性的重要策略:服务熔断、降级和限流。服务熔断通过快速失败和暂停故障服务调用来保护系统;服务降级在压力大时提供有限功能以保持整体可用性;限流控制访问频率,防止过载。文中列举了常见问题、解决方案,并提供了Go语言实现示例。合理应用这些策略能增强系统韧性和可用性。
136 0
|
12天前
|
Go
go创建web服务
go创建web服务
20 4
|
2天前
|
XML JSON Go
Swoole与Go系列教程之WebSocket服务的应用
在 WebSocket 协议出现之前,Web 应用为了能过获取到实时的数据都是通过不断轮询服务端的接口。轮询的效率、延时很低,并且很耗费资源。
22 1
Swoole与Go系列教程之WebSocket服务的应用
|
14天前
|
存储 中间件 Go
在go语言服务中封装路由和示例
【6月更文挑战第23天】本文介绍golang后端按协议处理、中间件(一次性与每次请求执行)划分、以及服务架构Controller、Logic/Service、DAO/Repository和Routers划分。代码仓库在GitHub上提供。使用框架简化了交互和处理。后续章节深入探讨服务构建。
107 5
在go语言服务中封装路由和示例
|
1天前
|
网络协议 Go
Swoole与Go系列教程之TCP服务的应用
TCP(传输控制协议)的出现是为了解决计算机网络中的数据可靠传输和连接管理的问题。在早期的计算机网络中,特别是在分组交换和互联网的发展初期,网络是不可靠的,存在丢包、错误和延迟等问题。
Swoole与Go系列教程之TCP服务的应用
|
4天前
|
网络协议 程序员 应用服务中间件
Swoole与Go系列教程之HTTP服务的应用
PHP 曾是Web开发领域佼佼者,随着业务壮大,异步和高并发方面不足显现。Swoole 曾经尝试填补空白,但局限性也比较的明显。Go 语言的崛起,简洁语法和并发优势吸引大厂使用,吸引了大多数程序员的转型。
12 0
Swoole与Go系列教程之HTTP服务的应用
|
18天前
|
网络协议 算法 Go
使用go的内置的基础路由服务
【6月更文挑战第19天】本文探索Go的HTTP服务:基础路由与多路复用。基础服务示例绑定到`:http`,返回非零错误。多路复用允许按URL模式匹配请求,长路径优先,注册时考虑主机名。错误路径重定向至根。代码示例见:https://github.com/hahamx/examples/tree/main/tcps/2_with_http_handler
101 6
|
1月前
|
关系型数据库 Go 开发工具
|
29天前
|
缓存 Java Go
如何用Go语言构建高性能服务
【6月更文挑战第8天】Go语言凭借其并发能力和简洁语法,成为构建高性能服务的首选。本文关注使用Go语言的关键设计原则(简洁、并发、错误处理和资源管理)、性能优化技巧(减少内存分配、使用缓存、避免锁竞争、优化数据结构和利用并发模式)以及代码示例,展示如何构建HTTP服务器。通过遵循这些原则和技巧,可创建出稳定、高效的Go服务。
|
16天前
|
Prometheus 监控 Cloud Native
Go服务监控
Go服务监控