简单的 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 服务了。

目录
相关文章
|
编译器 Go
Go 语言中的 gRPC 基础入门(下)
Go 语言中的 gRPC 基础入门(下)
83 0
|
编解码 中间件 Go
Go语言学习 - RPC篇:gRPC拦截器剖析
我们在前几讲提到过,优秀的RPC框架都提供了`middleware`的能力,可以减少很多重复代码的编写。在gRPC-Gateway的方案里,包括了两块中间件的能力: 1. gRPC中的`ServerOption`,是所有gRPC+HTTP都会被处理 2. gRPC-Gateway中的`ServeMuxOption`,只有HTTP协议会被处理 今天,我们先关注共同部分的`ServerOption`,它提供的能力最为全面,让我们一起了解下。
101 0
|
Cloud Native 架构师 Java
谷歌架构师分享gRPC与云原生应用开发Go和Java为例文档
随着微服务和云原生相关技术的发展,应用程序的架构模式已从传统的单体架构或分层架构转向了分布式的计算架构。尽管分布式架构本身有一定的开发成本和运维成本,但它所带来的收益是显而易见的。
|
5月前
|
网络协议 Go
|
8月前
|
自然语言处理 Java 编译器
【Go语言专栏】Go语言中的gRPC框架应用
【4月更文挑战第30天】Go语言的gRPC是一个高性能RPC框架,基于HTTP/2和Protocol Buffers,支持多语言。其特点包括高性能、强类型和双向流。在Go中使用gRPC,需定义接口(如hello.proto),生成Go代码,实现服务器端(注册服务到gRPC服务器)和客户端(调用服务)。此外,gRPC还提供流、错误处理和拦截器等高级特性,适用于复杂通信场景。
97 1
|
搜索推荐 Go 微服务
Go 语言怎么一键生成一个 gRPC 服务?
Go 语言怎么一键生成一个 gRPC 服务?
71 0
|
Go 微服务
Go 微服务工具包 Go kit 怎么集成 gRPC?
Go 微服务工具包 Go kit 怎么集成 gRPC?
100 0
|
编译器 Go 开发工具
Go 语言中的 gRPC 基础入门(上)
Go 语言中的 gRPC 基础入门
79 0
|
8月前
|
Java Go API
玩转gRPC—Go使用gRPC通信实战
玩转gRPC—Go使用gRPC通信实战
111 1
|
8月前
|
Cloud Native 安全 Go
Go语言与gRPC的完美结合
Go语言与gRPC的完美结合
256 0
Go语言与gRPC的完美结合