编写一个 gRPC 的示例。
gRPC 是谷歌开源的轻量级 RPC 通信框架,其中的通信协议基于二进制数据流,使得 gRPC 具有优异的性能。
gRPC 使用 protobuf 作为通信协议
两个微服务之间通过基于 HTTP 2.0 二进制数据帧通信,使用 gRPC 内置的 protobuf 协议,其 DSL 语法 可清晰定义服务间通信的数据结构
过程分解
实现一个 gRPC 调用,需要这么几步:
下面分解实现
写一个 .proto 文件,定义数据结果和服务方法,示例:
syntax = "proto3";
// 声明一个方法调用
service Greeter {
rpc SayHello (HelloRequest) returns (HelloReply) {}
}
// 请求消息
message HelloRequest {
string name = 1;
}
// 响应消息
message HelloReply {
string message = 1;
}
执行 protoc 生成源代码。
protoc --go_out=plugins=grpc:. helloworld/helloworld.proto
完成后,要确保生成的源代码放入你的项目中。
步骤如下:
package main
import (
context "context"
"fmt"
"google.golang.org/grpc"
"google.golang.org/grpc/examples/helloworld/helloworld"
pb "grpcdemo/helloworld"
"log"
"net"
)
type myServer struct {
helloworld.UnimplementedGreeterServer
}
// 端口号
const (
port = ":50051"
)
/**
实现接口
*/
func (*myServer) SayHello(ctx context.Context, req *pb.HelloRequest) (*pb.HelloReply, error) {
log.Printf("Received: %v", req.GetName())
reply := pb.HelloReply{Message: "Hello " + req.GetName()}
return &reply, nil
}
func main() {
// 准备一个 tcp 的监听器
listener1, err := net.Listen("tcp", port)
if err != nil {
log.Fatalf("出现异常: %v", err)
}
// 构建一个 grpc 服务
server1 := grpc.NewServer()
pb.RegisterGreeterServer(server1, &myServer{})
// 启动服务
fmt.Printf("服务启动 %v\n", port)
err = server1.Serve(listener1)
if err != nil {
log.Fatalf("启动server失败: %v", err)
}
}
步骤如下:
package main
import (
"context"
"fmt"
"google.golang.org/grpc"
pb "grpcdemo/helloworld"
"log"
"time"
)
// 服务地址
const (
address = "localhost:50051"
defaultName = "world"
)
func main() {
conn, err := grpc.Dial(address, grpc.WithInsecure(), grpc.WithBlock())
if err != nil {
log.Fatalf("连接失败: %v", err)
}
defer conn.Close()
// 获得一个调用方法 的stub
client := pb.NewGreeterClient(conn)
// 准备一个超时处理
ctx, cancel := context.WithTimeout(context.Background(), time.Second)
defer cancel()
// 执行 调用
fmt.Println("发起调用")
reply, err := client.SayHello(ctx, &pb.HelloRequest{Name: "zhang3"})
if err != nil {
log.Fatalf("调用失败: %v", err)
}
log.Printf("结果: %s", reply.GetMessage())
}
演示结果:
image.png