Go - 关于 proto 文件的一点小思考?

简介: Go - 关于 proto 文件的一点小思考?

文章目录:

  • 前言
  • helloworld.proto
  • 小思考
  • 小结
  • 推荐阅读


前言

ProtoBuf 是什么?

ProtoBuf 是一套接口描述语言(IDL),通俗的讲是一种数据表达方式,也可以称为数据交换格式。

我们常用的数据格式有 JSONXML,为什么使用 ProtoBuf ?是因为它的传输快,为什么传输快?大家可以找下资料。使用 .proto 文件进行描述要序列化的数据结构,然后将写好 .proto 文件使用 protoc 就可以很容易编译成众多计算机语言的接口代码。


gRPC 是什么?

gRPC 是开源的 RPC 框架,已支持主流的计算机语言,可以通过 ProtoBuf 进行定义接口,可以基于 ProtoBuf 进行数据传输。

两者虽然是一家,但是分别解决不同的问题,可以配合使用,也可以分开。


看一下的 gRPC helloworld 的 proto 文件是如何定义的?

helloworld.proto

syntax = "proto3";
package helloworld;
option go_package = "./;helloworld";
// The greeting service definition.
service Greeter {
  // Sends a greeting
  rpc SayHello (HelloRequest) returns (HelloReply) {}
}
// The request message containing the user's name.
message HelloRequest {
  string name = 1;
}
// The response message containing the greetings
message HelloReply {
  string message = 1;
}

文件中定义了一个 service Greeter 和 rpc SayHello 方法。

入参:string name

出参:string message

这些过于简单,还能不能描述其他信息? ab5b07458e71825bcedd1eb612b7c5a1.png

小思考

  1. 定义的 rpc 方法能否也同时支持 HTTP 调用?例如:SayHello 方法,既支持 gRPC 调用,也支持 HTTP 调用,同时支持 protoc 生成代码时,同时也生成 Swagger 接口文档。
  2. 定义的入参能否支持参数验证?例如:name 长度不能大于 20 个字符。
  3. 定义的 service Greeter 服务能否支持拦截器?例如:该服务下的所有方法需要进行登录令牌验证。
  4. 定义的 rpc SayHello 方法能够支持拦截器?例如:当前方法支持开启和关闭是否记录日志。

小结

以上问题还未完全解决,学习 gRPC 感觉有些吃力... ab5b07458e71825bcedd1eb612b7c5a1.png

大家有没有可以推荐的学习资源?目前在看 grpc-gateway[1]

推荐阅读

参考资料

[1]grpc-gateway: https://github.com/grpc-ecosystem/grpc-gateway

目录
相关文章
|
6月前
|
Go API
一文搞懂Go读写Excel文件
一文搞懂Go读写Excel文件
157 0
|
12月前
|
Go 区块链
go 编译 自定义 图标 ico文件
go 编译 自定义 图标 ico文件
85 0
|
Java 测试技术 Go
Go测试之.golden 文件
Go测试之.golden 文件
105 0
|
23天前
|
存储 Go 文件存储
M.2移动硬盘打造Win To Go系统:高效分区存储文件全攻略
【10月更文挑战第12天】本文详细介绍了如何使用M.2移动硬盘制作Win To Go系统。首先,需准备合适容量与接口类型的M.2硬盘及硬盘盒,并获取Windows镜像文件和分区工具。接着,通过Rufus软件将镜像写入硬盘。文中还提供了分区策略,包括系统分区(约80-120GB)、软件分区(根据需求设定)和数据分区(剩余空间),并指导如何使用DiskGenius或Windows自带工具进行分区。最后,强调了对各分区文件的有效管理和定期备份的重要性。
|
24天前
|
存储 固态存储 Go
M.2移动硬盘打造Win To Go系统:高效分区存储文件全攻略
【10月更文挑战第11天】Win To Go 是一种将 Windows 系统安装在 M.2 移动硬盘上的技术,便于用户携带自定义系统跨设备使用。需准备高性能 M.2 硬盘及合适硬盘盒,并使用 DiskGenius 或 Rufus 进行分区与系统安装。系统分区用于安装 Windows,其余分区可根据需求存储工作或娱乐文件,便于管理和备份。
|
5月前
|
JavaScript
vue : 无法加载文件 D:\module\npm_module\npm_modules\vue.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参阅 https:/go.microsoft.c
vue : 无法加载文件 D:\module\npm_module\npm_modules\vue.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参阅 https:/go.microsoft.c
|
5月前
|
监控 Go
go语言并发实战——日志收集系统(十) 重构tailfile模块实现同时监控多个日志文件
go语言并发实战——日志收集系统(十) 重构tailfile模块实现同时监控多个日志文件
|
5月前
|
存储 监控 算法
go语言并发实战——日志收集系统(四) 利用tail包实现对日志文件的实时监控
go语言并发实战——日志收集系统(四) 利用tail包实现对日志文件的实时监控
|
5月前
|
Go
Go语言进阶篇——文件
Go语言进阶篇——文件
|
6月前
|
安全 Go
Golang深入浅出之-Go语言标准库中的文件读写:io/ioutil包
【4月更文挑战第27天】Go语言的`io/ioutil`包提供简单文件读写,适合小文件操作。本文聚焦`ReadFile`和`WriteFile`函数,讨论错误处理、文件权限、大文件处理和编码问题。避免错误的关键在于检查错误、设置合适权限、采用流式读写及处理编码。遵循这些最佳实践能提升代码稳定性。
70 0