【grpc】grpc进阶一,再回首protobuf

在之前的章节里,我们了解了 protobuf 的基本规则和使用方法,生成了 grpc 代码并成功运行。那么我们还要思考一个问题,protobuf 文件到底该如何管理。我们知道 grpc 是区分客户端和服务端的,一般而言,客户端和服务端是分两个工程,如果是在一个工程里也没有使用 rpc 的必要了。这样就会有一个问题,protobuf 文件如何共享?

我们进入正文,关于 protobuf 文件管理的方法在网上有挺多,我比较倾向于 git 子模块的管理方式。把 protobuf 文件抽出来单独建立一个 git 项目,实际调用到 protobuf 的项目中添加 protobuf 的项目为子模块,下面就我们之前的例子实际讲述一下。

一、建立 protobuf git 项目

首先要建立 protobuf 的 git 仓库。我们把前几篇中使用的工程的子目录 proto 单独拿出来,进到目录下创建 git 项目,然后推送到 git 仓库里,我这边的地址是 https://gitee.com/sauryniu/grpc-demo-proto.git

二、添加 git 子模块

回到我们的 grpcDemo 目录下,初始化为 git 工程,然后执行子模块添加命令:

bash 复制代码
git submodule add https://gitee.com/sauryniu/grpc-demo-proto.git ./proto

推送到仓库,可以看到状态为:

看下本地的目录:

好像一切都没变,但一切都变了...

相关推荐
清水白石0081 小时前
在 RESTful、RPC 与事件驱动之间做选择:高频内部调用与审计回放场景下的架构取舍
rpc·架构·restful
喵了几个咪1 小时前
Kratos 生态双定时器中间件:高精度 hptimer 与标准 cron 选型与实践
微服务·中间件·架构·golang·kratos
Achou.Wang3 小时前
Concurrency patterns - Go 并发模式
开发语言·后端·golang
存在morning3 小时前
【GO语言开发实践】三 GO 工程化快速上手
开发语言·后端·golang
Achou.Wang3 小时前
Go语言并发编程中的死锁防范与破解之道
服务器·开发语言·golang
子安柠3 小时前
深入理解 Go 反射:原理、实践与性能陷阱
开发语言·golang
福大大架构师每日一题3 小时前
ollama v0.24.0 更新:Codex App 正式接入、内置浏览器、评审模式与 MLX 采样器重构,带来哪些变化?
重构·golang
会编程的土豆4 小时前
Go ini 配置加载:`ini.MapTo` 详细解析
开发语言·数据库·golang
喵了几个咪5 小时前
Kratos KCP 传输中间件:游戏开发低延迟网络通信实战指南
微服务·中间件·golang·游戏开发·kratos
Full Stack Developme5 小时前
Spring Context 解析
java·spring·rpc