go-micro
是一种可插拔的RPC分布式系统微服务开发框架,这一章主要介绍一下入门的相关内容。
服务发现依赖项
首先 micro
这个框架需要且依赖于服务发现工具(service discovery),框架默认的服务发现工具是 Consul
,同时框架的插拔机制也可确保能够切换到其他的服务发现工具上,如Etcd、NATS等,详见 micro plugins
;
关于consul
的安装与运行:
1 | $ brew install consul # 安装 |
gRPC的安装
由于 micro
框架基于 gRPC
,故需要安装相关依赖项,同时安装时确保 go version
版本在1.6
以上;
安装gRPC
1 | $ go get -u google.golang.org/grpc |
安装Protocol Buffers v3
安装用于生成gRPC
服务代码的protoc
编译器工具;
最简单的方式是通过在protobuf工具文件列表中,以查看protoc-<version>-<platform>.zip
文件名格式的方式找出符合你当前版本及系统平台的安装包,找到后下载解压放置于bin
目录、修改环境变量PATH等;
同时安装protoc go插件
1 | $ go get -u github.com/golang/protobuf/protoc-gen-go |
Micro相关安装
框架包的安装
1 | $ go get github.com/micro/go-micro |
protoc micro插件安装
用于通过.proto
文件生成.micro.go
代码文件
1 | $ go get github.com/micro/protoc-gen-micro |
micro工具包的安装
1 | $ go get github.com/micro/micro |
micro 命令行工具可以提供诸如服务列表查看、服务详情查看、调用服务接口等功能;
实践一下
首先,创建一个user.proto
结构文件
1 | syntax = "proto3"; |
其次,通过proto文件编译生成代码
1 | protoc --proto_path=$GOPATH/src:. --micro_out=. --go_out=. user.proto |
此时,通过protoc
工具对user.proto
文件的编译,生成了两个go文件:
- user.micro.go
- user.pb.go
然后,分别编写服务端及客户端代码
服务端 service.go
1 | package main |
客户端 client.go
1 | package main |
最后,运行起来
首先启动服务发现
1 | $ consul agent -dev |
可通过访问:http://127.0.0.1:8500/ui/ 查看服务;
启动服务端程序
1 | $ go run service.go |
此时刷新:http://127.0.0.1:8500/ui/ 页面会发现新服务user
;
执行客户端程序,调用接口
1 | $ go run client.go |