不忘初心,砥砺前行
作者 | 莫无崖
转载请联系授权
了解了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 "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服务架构
▼关注我,一起成长
主要分享 学习心得、笔记、随笔▼