5、编写gRPC服务端程序
这里先上代码:
package main import ( "context" "fmt" "grpchello/proto" "log" "time" "github.com/asim/go-micro/plugins/server/grpc/v4" "go-micro.dev/v4" "go-micro.dev/v4/server" ) type Hello struct{} func (s *Hello) Say(ctx context.Context, req *proto.SayRequest, rsp *proto.SayResponse) error { fmt.Println("request:", req.Name) rsp.Message = "Hello " + req.Name return nil } func main() { grpcServer := grpc.NewServer() service := micro.NewService( micro.Server(grpcServer), micro.Name("grpchello.service"), micro.Address("0.0.0.0:8001"), micro.RegisterTTL(time.Second*30), micro.RegisterInterval(time.Second*10), ) // optionally setup command line usage service.Init() // Register Handlers proto.RegisterHelloHandler(service.Server(), &Hello{}) // Run server if err := service.Run(); err != nil { log.Fatal(err) } }
整个过程如下:
先定义一个名为 Hello 的类型,它去实现hello.pb.micro.go中生成的HelloHandler接口,也就是编写具体的业务实现。
然后通过grpc.NewServer创建一个gRPC服务器,这里决定go-micro底层通信使用gPRC;
然后通过micro.NewService创建一个micro服务,这里需要传入上面创建的grpc server,还要设置服务的名称、监听端口,以及保持服务健康用的TTL和上报周期。go-mico当前默认的服务发现机制是mdns,不用额外部署服务发现工具,不过一般只建议在开发环境使用,生产环境建议使用etcd;
通过上面的步骤对服务进行一些初始化之后,再将Hello类型的实例注册到grpc server;
最后启动服务,就可以开始接客了。
如果直接粘贴这段代码的话,会有很多包没有引用进来,可以通过 go get 获取这些包,也可以执行命令:go mod tidy 来引入需要的包。
这里边还import了一个 grpchello/proto ,这个是我这边项目的mod是 grpchello,gRPC代理程序的package是proto,如果你的不一样,需要修改下。
6、编写gRPC客户端程序
访问gRPC服务也是通过 hello.pb.micro.go 中生成的方法,直接上代码:
package main import ( "bufio" "context" "fmt" "grpchello/proto" "os" "github.com/asim/go-micro/plugins/client/grpc/v4" "go-micro.dev/v4" ) func main() { service := micro.NewService( micro.Client(grpc.NewClient()), ) service.Init() client := proto.NewHelloService("grpchello.service", service.Client()) rsp, err := client.Say(context.TODO(), &proto.SayRequest{Name: "BOSSMA"}) if err != nil { fmt.Println(err) } fmt.Println(rsp) fmt.Println("按回车键退出程序...") in := bufio.NewReader(os.Stdin) _, _, _ = in.ReadLine() }
上面的程序使用了 grpc.NewClient , 这决定了底层通信采用gRPC;然后再使用生成的代码 proto.NewHelloService 创建客户端代理,这里指定的服务名字必须是服务端注册的名字;最后使用这个客户端代理调用相应的方法。
7、运行程序
可以使用 go run xxx.go 来编译并运行程序。这里为了方便测试,先使用 go build 将它们编译为exe,然后再双击运行。实际运行效果如下:
以上就是本文的主要内容了,完整代码示例已经上传到 Github:github.com/bosima/go-d…