域名 AXUM.RS 将于2025年10月到期。我们无意再对其进行续费,我们希望你能够接续这个域名,让更多 AXUM 开发者继续受益。
  • 方案1️⃣AXUM.RS 域名 = 3000
  • 方案2️⃣方案1️⃣ + 本站所有专题原始 Markdown 文档 = 5000
  • 方案3️⃣方案2️⃣ + 本站原始数据库 = 5500
如果你有意接续这份 AXUM 情怀,请与我们取得联系。
说明:
  1. 如果有人购买 AXUM.RS 域名(方案1️⃣),或者该域名到期,本站将启用新的免费域名继续提供服务。
  2. 如果有人购买了 AXUM.RS 域名,且同时购买了内容和/或数据库(方案2️⃣/方案3️⃣),本站将关闭。届时我们或许会以另一种方式与你再相遇。

跨语言调用

本专题将带你通过 gRPC 实现 Rust 和 Go 语言的跨语言调用。

目标

  • 基于 gPRC 官方的 helloworld 案例
  • 使用 Rust 实现此案例的服务端和客户端
  • 使用 Go 实现此案例的服务端和客户端
  • 使用 Rust 实现的客户端分别调用 Rust 和 Go 实现的服务端
  • 使用 Go 实现的客户端分别调用 Rust 和 Go 实现的服务端

项目结构

├── helloworld_go ➡️ go 实现
│   ├── client ➡️ go 实现的客户端
│   │   └── main.go
│   ├── go.mod
│   ├── go.sum
│   ├── pb  ➡️ 根据 proto 生成的 go 代码
│   │   ├── helloworld.pb.go
│   │   └── helloworld_grpc.pb.go
│   └── server ➡️ go 实现的服务端
│       └── main.go
├── helloworld_rs  ➡️ rust 实现
│   ├── Cargo.lock
│   ├── Cargo.toml
│   ├── build.rs ➡️ 在构建时,自动根据 proto 生成 rust 代码
│   └── src
│       ├── client.rs  ➡️ rust 实现的客户端
│       ├── pb ➡️ 根据 proto 生成的 rust 代码
│       │   ├── helloworld.rs
│       │   └── mod.rs
│       └── server.rs  ➡️ rust 实现的服务端
└── proto ➡️  proto 代码
    └── helloworld.proto

helloworld.proto

本专题对 helloworld.proto 作了有关 package 的修改:

  • 删除 java 相关的包定义
  • 增加 go 需要的包定义
syntax = "proto3";
option go_package = "helloworld_go/pb"; // go 语言的包名
package helloworld; // rust 会根据此定义生成 mod
// 定义 Greeter 服务
service Greeter {
  // 发送问候
  rpc SayHello (HelloRequest) returns (HelloReply) {}
}
// 发送问候的请求,包含用户的名字
message HelloRequest {
  string name = 1;
}
// 问候的响应
message HelloReply {
  string message = 1;
}

开始学习

cargo new helloworld_rs

创建go项目,比如 helloworld_go

mkdir helloworld_go && \
go mod init helloworld_go

创建 proto 目录,并写入 helloworld.proto

mkdir proto && \
cat > proto/helloworld.proto << EOF
syntax = "proto3";
option go_package = "helloworld_go/pb"; // go 语言的包名
package helloworld; // rust 会根据此定义生成 mod
// 定义 Greeter 服务
service Greeter {
  // 发送问候
  rpc SayHello (HelloRequest) returns (HelloReply) {}
}
// 发送问候的请求,包含用户的名字
message HelloRequest {
  string name = 1;
}
// 问候的响应
message HelloReply {
  string message = 1;
}
EOF

本专题代码在axum/grpc_helloworld_go_rust

要查看完整内容,请先登录