简单的 Go gRPC 例子

简介: 简单的 Go gRPC 例子

以下是一个简单的 Go gRPC 例子,其中包括服务端和客户端:
首先,我们需要安装 grpcprotobuf 的 Go 插件:

go get -u google.golang.org/grpc
go get -u github.com/golang/protobuf/protoc-gen-go

然后,我们需要定义一个 .proto 文件来定义我们的服务和消息。这里是一个示例 .proto 文件:

protobuf
syntax = "proto3";

package example;

service Greeter {
   
  rpc SayHello (HelloRequest) returns (HelloResponse);
}

message HelloRequest {
   
  string name = 1;
}

message HelloResponse {
   
  string message = 1;
}

接下来,我们使用 protoc 工具来生成 Go 代码:

protoc --go_out=plugins=grpc:. *.proto

这将在当前目录下生成 example.pb.go 文件,其中包含我们定义的服务和消息的 Go 代码。
接下来,我们可以编写服务端代码:

package main

import (
    "context"
    "google.golang.org/grpc"
    "log"
    "net"
    pb "path/to/your/proto/package"
)

type server struct{
   }

func (s *server) SayHello(ctx context.Context, req *pb.HelloRequest) (*pb.HelloResponse, error) {
   
    return &pb.HelloResponse{
   
        Message: "Hello, " + req.Name + "!",
    }, nil
}
func main() {
   
    lis, err := net.Listen("tcp", ":50051")
    if err != nil {
   
        log.Fatalf("failed to listen: %v", err)
    }
    s := grpc.NewServer()
    pb.RegisterGreeterServer(s, &server{
   })
    log.Println("Starting server on port 50051...")
    if err := s.Serve(lis); err != nil {
   
        log.Fatalf("failed to serve: %v", err)
    }
}

在这个例子中,我们定义了一个名为 server 的结构体,并实现了 SayHello 方法来响应客户端的请求。我们还在 main 函数中创建了一个 grpc.Server 实例,并将我们的服务注册到该实例上。最后,我们使用 Serve 方法来启动服务端并监听端口 50051
现在,我们可以编写客户端代码:

package main
import (
    "context"
    "log"
     "google.golang.org/grpc"
     pb "path/to/your/proto/package"
)

func main() {
   
    conn, err := grpc.Dial(":50051", grpc.WithInsecure())
    if err != nil {
   
        log.Fatalf("failed to connect: %v", err)
    }
    defer conn.Close()
     c := pb.NewGreeterClient(conn)
     resp, err := c.SayHello(context.Background(), &pb.HelloRequest{
   Name: "World"})
    if err != nil {
   
        log.Fatalf("failed to call SayHello: %v", err)
    }
     log.Printf("Response: %s", resp.Message)
}

在这个例子中,我们首先使用 grpc.Dial 方法来连接到服务端,然后创建一个 GreeterClient 实例来调用服务端的 SayHello 方法。最后,我们输出响应的消息。
现在,我们可以运行服务端和客户端来测试我们的 gRPC 服务了。

目录
相关文章
|
7月前
|
网络协议 Go
|
10月前
|
自然语言处理 Java 编译器
【Go语言专栏】Go语言中的gRPC框架应用
【4月更文挑战第30天】Go语言的gRPC是一个高性能RPC框架,基于HTTP/2和Protocol Buffers,支持多语言。其特点包括高性能、强类型和双向流。在Go中使用gRPC,需定义接口(如hello.proto),生成Go代码,实现服务器端(注册服务到gRPC服务器)和客户端(调用服务)。此外,gRPC还提供流、错误处理和拦截器等高级特性,适用于复杂通信场景。
127 1
|
10月前
|
Java Go API
玩转gRPC—Go使用gRPC通信实战
玩转gRPC—Go使用gRPC通信实战
136 1
|
10月前
|
Cloud Native 安全 Go
Go语言与gRPC的完美结合
Go语言与gRPC的完美结合
294 0
Go语言与gRPC的完美结合
|
10月前
|
Go
简单的 Go gRPC 例子
简单的 Go gRPC 例子
91 0
|
数据可视化 Java 中间件
gRPC的请求追踪神器go tool trace
gRPC的请求追踪神器go tool trace
106 0
|
JSON Linux 测试技术
go语言处理数据、基本通信以及环境配置 -- json,protobuf,grpc
go语言处理数据、基本通信以及环境配置 -- json,protobuf,grpc
|
搜索推荐 Go 微服务
Go 语言怎么一键生成一个 gRPC 服务?
Go 语言怎么一键生成一个 gRPC 服务?
83 0
|
Go 微服务
Go 微服务工具包 Go kit 怎么集成 gRPC?
Go 微服务工具包 Go kit 怎么集成 gRPC?
112 0
|
编译器 Go
Go 语言中的 gRPC 基础入门(下)
Go 语言中的 gRPC 基础入门(下)
87 0