美文网首页
go语言实现的rpc简单示例

go语言实现的rpc简单示例

作者: 追梦人在路上不断追寻 | 来源:发表于2024-02-20 12:41 被阅读0次

1. 创建一个新的 Go 项目目录

mkdir grpc_example
cd grpc_example

2. 定义 .proto 文件

先创建pb文件夹,然后进入里面创建.proto文件。

mkdir pb
cd pb
syntax = "proto3";

package helloworld;

option go_package = ".";

service Greeter {
  rpc SayHello (HelloRequest) returns (HelloReply) {}
}

message HelloRequest {
  string name = 1;
}

message HelloReply {
  string message = 1;
}

3. 使用 protoc 工具生成 Go 代码

protoc --go_out=. --go-grpc_out=. helloworld.proto

这里需要注意的是需要安装protoc工具,并且还要安装golang关于protoc的命令行工具。

sudo apt update
sudo apt install protobuf-compiler
# 安装 protoc-gen-go 和 protoc-gen-go-grpc
go install google.golang.org/protobuf/cmd/protoc-gen-go@latest
go install google.golang.org/grpc/cmd/protoc-gen-go-grpc@latest

4. 创建服务端代码 server.go

package main

import (
    "context"
    "fmt"
    "net"

    "google.golang.org/grpc"
    "google.golang.org/grpc/reflection"

    pb "path/to/your/grpc_example/pb" // 替换为生成的 pb 包的实际路径
)

type server struct{
        pb.UnimplementedGreeterServer // 嵌入 UnimplementedGreeterServer 结构体

}

func (s *server) SayHello(ctx context.Context, in *pb.HelloRequest) (*pb.HelloReply, error) {
    return &pb.HelloReply{Message: "Hello " + in.Name}, nil
}

func main() {
    lis, err := net.Listen("tcp", ":50051")
    if err != nil {
        fmt.Println("failed to listen: ", err)
        return
    }
    s := grpc.NewServer()
    pb.RegisterGreeterServer(s, &server{})
    reflection.Register(s)
    fmt.Println("server started at :50051")
    if err := s.Serve(lis); err != nil {
        fmt.Println("failed to serve: ", err)
        return
    }
}

5. 创建客户端代码

package main

import (
    "context"
    "fmt"
    "log"

    pb "github.com/xxx/grpc_example/pb" 
    "google.golang.org/grpc"
)

func main() {
    conn, err := grpc.Dial("localhost:50051", grpc.WithInsecure())
    if err != nil {
        log.Fatalf("failed to connect: %v", err)
    }
    defer conn.Close()
    c := pb.NewGreeterClient(conn)

    name := "world"
    r, err := c.SayHello(context.Background(), &pb.HelloRequest{Name: name})
    if err != nil {
        log.Fatalf("failed to call SayHello: %v", err)
    }
    fmt.Println("Greeting:", r.Message)
}

代码结构

.
├── client.go
├── go.mod
├── go.sum
├── pb
│   ├── helloworld_grpc.pb.go
│   ├── helloworld.pb.go
│   └── helloworld.proto
├── readme.txt
└── server.go

1 directory, 8 files

相关文章

  • Java RPC

    Java 基于TCP协议实现的RPC简单示例 [文档] Java RPC.docx

  • grpc

    Go的RPC标准库 简单使用 Go语言标准库(net/rpc)的RPC规则:方法只能有两个可序列化的参数,其中第二...

  • 一个Go语言程序示例

    本文档介绍来自《Go语言编程》的简单Go语言程序示例。 程序结构 本程序是一个排序算法的实现,程序结构如下所示 创...

  • go rpc示例

    最近在Youtube上面看到一个关于:golang rpc包的示例视频:youtube视频地址:Building ...

  • Go语言实现RPC

    RPC定义,来源于百度百科 RPC(Remote Procedure Call)—远程过程调用,它是一种通过网络从...

  • 在Go语言中基础的Redis操作

    在Go语言中基础的Redis操作 需要先安装redigo Go语言Redis客户端的简单示例 连接池 POOL 为...

  • golang jsonrpc

    Go语言的rpc框架有两个比较有特色的设计: RPC打包时可以通过插件实现自定义编码和解码; RPC建立在抽象的i...

  • 基于Netty+动态代理+反射 实现简单的RPC调用

    前言 本文只是简单实现了一次RPC调用示例,以理解其调用原理。一些主流RPC框架的其他功能并没有实现。(如服务自动...

  • golang-rpc

    参考 golang中的RPC调用服务器方法 golang rpc的两种调用方法 Go官方库RPC开发指南 示例 s...

  • 【golang微服务】RPC原理与Go RPC

    本文介绍了RPC的概念以及Go语言中标准库rpc的基本使用。 什么是RPC RPC(Remote Procedur...

网友评论

      本文标题:go语言实现的rpc简单示例

      本文链接:https://www.haomeiwen.com/subject/msebadtx.html