不忘初心,砥砺前行
作者 | 莫无崖
转载请联系授权
了解了Micro的基本框架之后,我们做一个简单的例子来实现客户端与服务端的通信,在了解本篇文章之前,需要你对rpc、grpc通信技术有所了解。
1## 安装go-micro 2go get github.com/micro/go-micro 3## 安装micro 4go get github.com/micro/micro 5## 安装grpc 6go get -u google.golang.org/grpc 7## 安装grpc插件 8go get -u github.com/golang/protobuf/protoc-gen-go 9## 安装micro插件 10go get github.com/micro/protoc-gen-micro 11# 设置环境变量,便于命令行操作 12export PATH=$PATH:$GOPATH/bin
服务端
定义一个common.proto
1syntax = "proto3"; 2 3package go.micro.srv.demo; 4 5message Request { 6 string msg = 1; 7} 8 9message Pair { 10 int32 key = 1; 11 string values = 2; 12} 13 14message Response { 15 string msg = 1; 16 // 数组 17 repeated string values = 2; 18 // map 19 map<string,Pair> header= 3; 20 RespType type = 4; 21} 22// enum 23enum RespType{ 24 NONE = 0; 25 ASCEND = 1; 26 DESCEND = 2; 27} 28// 服务接口 29service Say { 30 rpc Hello (Request) returns (Response); 31}
使用插件生成相关代码
1protoc --go_out=. --micro_out=. proto/demo/common.proto
可以看到在目录中多了两个文件
现在开始创建我们的服务,编写实现服务的方法,这里的参数格式必须要按照如下格式写。demo是导进去的包,即你编写proto文件名的包,我在这里由于使用了go mod init github.com/yuwe1/micolearn进行初始化了项目,因此导入的包可以直接写成demo "github.com/yuwe1/micolearn/day01/demoservice/proto/demo"
1type Say struct{} 2func (s *Say) Hello(ctx context.Context, req *demo.Request, rsp *demo.Response) error { 3 fmt.Println("received", req.Msg) 4 rsp.Header = make(map[string]*demo.Pair) 5 rsp.Header["name"] = &demo.Pair{Key: 1, Values: "abc"} 6 rsp.Msg = "Hello World" 7 rsp.Values = append(rsp.Values, "a", "b") 8 rsp.Type = demo.RespType_DESCEND 9 return nil 10}
注册我们的服务在main函数中,在这里面仅仅添加了一行注册的代码在3段式中。
1srv := micro.NewService( 2 micro.Name("go.micro.srv.demo"), 3 micro.Version("latest"), 4) 5srv.Init() 6demo.RegisterSayHandler(srv.Server(), new(Say)) 7// run server 8if err := srv.Run(); err != nil { 9 panic(err) 10}
启动我们的服务,可以看到成功注册了一个名字叫demo的服务。
客户端
比较简单,这里直接贴上源码,需要注意的是,客户端首先获取到服务,然后直接调用了服务函数
1package main 2 3import ( 4 "context" 5 "fmt" 6 7 microclient "github.com/micro/go-micro/client" 8 //需要更换成你自己的包,在服务端的那部分包,同样也需要更改 9 demo "github.com/yuwe1/micolearn/day01/demoservice/proto/demo" 10) 11 12func main() { 13 client := demo.NewSayService("go.micro.srv.demo", microclient.DefaultClient) 14 r, err := client.Hello(context.Background(), &demo.Request{Msg: "hahaahah"}) 15 if err != nil { 16 panic(err) 17 } 18 fmt.Println(r) 19}
运行我们的客户端
服务端控制台成功打印数据
END
今日推荐阅读
RabbitMQ系列笔记广播模式和路由模式
RabbitMQ系列笔记入门篇RabbitMQ系列笔记work模式
RabbitMQ系列笔记work模式
protoc语法详解及结合grpc定义服务
Golang中Model的使用
基于Nginx和Consul构建高可用及自动发现的Docker服务架构
▼关注我,一起成长
主要分享 学习心得、笔记、随笔▼