grpc - gRPC 消息格式
问题描述
我想知道如何正确构建 GRPC 请求和响应。我在“编解码器”部分只找到了两个资源:
- 编码:https ://developers.google.com/protocol-buffers/docs/encoding
- HTTP/2:https ://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md#message-encoding
我相信我理解这两个文件。我了解 HTTP/2 框架是如何工作的(我在 Rust 中实现了自己的 HTTP/2 服务器和客户端,所以我详细了解了它),但是发送的消息总是以某种方式无效。
让我们以这个简单的消息(proto3)为例:
message Test1 {
int32 a = 1;
}
我现在只处理响应部分。值的电汇格式150
(如 google 示例中所指定)应为 Hex[08, 96, 01] ([00001000, 10010110, 00000001])。我将它打包到一个 DATA 帧中,并将其作为响应发送回 GRPC 客户端。这是响应的样子:
...
[ 0.010] recv SETTINGS frame <length=0, flags=0x00, stream_id=0>
(niv=0)
00000000 00 00 00 04 01 00 00 00 00 |.........|
00000009
[ 0.010] recv SETTINGS frame <length=0, flags=0x01, stream_id=0>
; ACK
(niv=0)
[ 0.010] send SETTINGS frame <length=0, flags=0x01, stream_id=0>
; ACK
(niv=0)
00000000 00 00 0e 01 04 00 00 00 0d 88 5f 8b 1d 75 d0 62 |.........._..u.b|
00000010 0d 26 3d 4c 4d 65 64 |.&=LMed|
00000017
[ 0.012] recv (stream_id=13) :status: 200
[ 0.012] recv (stream_id=13) content-type: application/grpc
[ 0.012] recv HEADERS frame <length=14, flags=0x04, stream_id=13>
; END_HEADERS
(padlen=0)
; First response header
00000000 00 00 03 00 00 00 00 00 0d 08 96 01 |............|
0000000c
[ 0.016] recv DATA frame <length=3, flags=0x00, stream_id=13>
00000000 00 00 0f 01 05 00 00 00 0d 40 0b 67 72 70 63 2d |.........@.grpc-|
00000010 73 74 61 74 75 73 81 07 |status..|
00000018
[ 0.016] recv (stream_id=13) grpc-status: 0
[ 0.016] recv HEADERS frame <length=15, flags=0x05, stream_id=13>
; END_STREAM | END_HEADERS
(padlen=0)
[ 0.021] send GOAWAY frame <length=8, flags=0x00, stream_id=0>
(last_stream_id=0, error_code=NO_ERROR(0x00), opaque_data(0)=[])
必须缺少标题,否则我缺少消息格式。有人可以使用curl
. 谢谢!
解决方案
我意识到Length-Prefixed-Message
实际上是这样的,Length-Prefixed, Message
所以每个 DATA 有效负载都必须加上前缀。
推荐阅读
- flutter - Flutter - 在 FutureBuilder 中等待 setState 然后加载组件
- angular - 子路由上的页面重新加载不起作用
- plsql - 如何避免 Informatica 中的垃圾字符
- unit-testing - 是否可以克隆/分支先前引发异常的传奇
- python - 如何单击与另一个字符串在同一行中的链接?
- python - 关于以某种方式创建CNN的问题(没有model.add)
- c++ - 如果平凡的默认构造函数不执行任何操作,为什么我们不能使用 malloc 创建平凡的可构造对象?
- javascript - 使用 insertBefore 后无法移动元素
- powershell - 如何迭代特定模式的文件名以在 FFMPEG 和 PowerShell 上使用它
- amazon-web-services - ssl 证书续订并重新导入到 aws