forked from printfcoder/stack-rpc-tutorials
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathmain.go
52 lines (42 loc) · 1.22 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
package main
import (
"context"
"fmt"
"github.com/micro/go-micro/v2/client"
"github.com/micro/go-micro/v2/client/grpc"
"github.com/micro/go-micro/v2/metadata"
"github.com/micro/go-micro/v2/registry/mdns"
)
// 请求参数结构只要对方服务能识别的就行
type whatEverReq struct {
Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"`
}
// 响应结构只要我方服务能识别的就行
type whatEverRsp struct {
Message string `protobuf:"bytes,2,opt,name=message,proto3" json:"message,omitempty"`
}
func main() {
cli := grpc.NewClient(
// 与目录服务同注册中心即可
client.Registry(mdns.NewRegistry()),
)
// 调用目标服务的结构
req := cli.NewRequest("go.micro.rpc.example", "Example.Call",
&whatEverReq{
Name: "John",
},
// 不确定对方服务时,需要使用JSON格式,而不是protobuf
client.WithContentType("application/json"))
// 自定义元数据
ctx := metadata.NewContext(context.Background(), map[string]string{
"X-User-Id": "john",
"X-From-Id": "script",
})
rsp := &whatEverRsp{}
// 调用服务
if err := cli.Call(ctx, req, rsp); err != nil {
fmt.Println("call err: ", err, rsp)
return
}
fmt.Println("rsp: ", rsp.Message)
}