gRPC RPC技术demo
假如已经安装好了protoc,下载地址:下载地址
新建一个项目如:demo01
初始化:go mod init demo01
安装这两个包:
go install google.golang.org/protobuf/cmd/protoc-gen-go@latest
go install google.golang.org/grpc/cmd/protoc-gen-go-grpc@latest
在demo01下新建pb文件夹,然后在pb文件夹下新建pb.proto
pb.proto代码:
syntax = "proto3";
option go_package = "./;pb";
package pb;
service Greeter{
rpc SayHello (HelloRequest) returns (HelloResponse) {}
}
// 请求数据格式
message HelloRequest{
string name = 1;
}
// 返回数据格式
message HelloResponse{
string message = 1;
}
如果语法不高亮的话,可以在vscode安装插件:vscode-poroto3
分别在终端执行:
protoc --go_out=./pb ./pb/hello.proto
protoc --go_grpc_out=./pb ./pb/hello.proto
就会在pb文件夹下生成 hello_grpc.pb.go与hello.pb.go这两个文件
在demo01新建server,然后在server下新建main.go文件,main.go代码如下:
package main
import (
"context"
pb "demo01/pb"
"fmt"
"log"
"net"
"google.golang.org/grpc"
"google.golang.org/grpc/reflection"
)
const (
port = ":50051"
)
// 服务对象
type server struct {
pb.UnimplementedGreeterServer
}
// sayhello实现服务的接口 在proto中定义的所有服务都是接口
func (s *server) SayHello(ctx context.Context, in *pb.HelloRequest)(*pb.HelloResponse,error){
return &pb.HelloResponse{Message: "Hello " + in.Name},nil
}
func main() {
lis, err := net.Listen("tcp", port)
if err != nil {
log.Fatalf("failed to listen: %v", err)
}
// 起一个服务
s := grpc.NewServer()
pb.RegisterGreeterServer(s, &server{})
// 注册反射服务 这个服务是CLI使用的 跟服务本身没有关系
fmt.Printf("\"开始提供服务\": %v\n", "开始提供服务")
reflection.Register(s)
if err := s.Serve(lis); err != nil {
log.Fatalf("failed to serve %v",err)
}
}
在demo01新建client,然后在client下新建main.go文件,main.go代码如下:
package main
import (
"context"
pb "demo01/pb"
"time"
"log"
"os"
"google.golang.org/grpc"
)
const (
address = "localhost:50051"
defaultName = "world"
)
func main() {
// 建立连接
conn, err := grpc.Dial(address, grpc.WithInsecure())
if err != nil {
log.Fatalf("did not connect :%v",err)
}
defer conn.Close()
c := pb.NewGreeterClient(conn)
name := defaultName
if len(os.Args) > 1{
name = os.Args[1]
}
// 1秒的上下文
ctx, cancel := context.WithTimeout(context.Background(), time.Second)
defer cancel()
r, err := c.SayHello(ctx, &pb.HelloRequest{Name: name})
if err != nil {
log.Fatalf("could not greet: %v",err)
}
log.Printf("Greeting: %s",r.Message)
}
进入server文件夹下执行:go run main.go 用来启动服务端
进入client文件夹下执行:go run main.go baixiaobai 用来启动客户端