h2 的帧
h2 的传输过程中最重要的角色就是帧了。
h2 的其他相关文章
深入 HTTP2(帧,消息,流)
H2 升级前的调研
-
Length
: 代表整个 frame 的长度,用一个 24 位无符号整数表示
但是这不意味着就能处理 2^24 16M大小的帧,一般是默认只支持2^16 16k以下的帧,而2^16 - 2^24 16M 的帧 需要接收端公布自己可以处理这么大的帧,需要在 SETTINGS_MAX_FRAME_SIZE 帧中告知。
-
Type
: 定义 frame 的类型。帧类型决定了帧主体的格式和语义,如果 type 为 unknown 应该忽略或抛弃。
帧类型 | 编码类型 | 用途 |
---|---|---|
DATA | 0x0 | 传递HTTP包体 |
HEADERS | 0x1 | 传递HTTP包头 |
PRIORITY | 0x2 | 指定Stream 流的优先级 |
RST_STREAM | 0x3 | 终止Stream流 |
SETTINGS | 0x4 | 修改连接或者Stream流的配置 |
PUSH_PROMISE | 0x5 | 服务端推送资源时描述请求的帧 |
PING | 0x6 | 心跳监测兼具测量RTT的功能 |
GOAWAY | 0x7 | 优雅的终止错误或通知错误 |
WINDOW_UPDATE | 0x8 | 实现流量控制 |
CONTINUATION | 0x9 | 传递较大HTTP头部时的持续帧 |
-
Flags
:是为帧类型相关而预留的布尔标识。标识对于不同的帧类型赋予了不同的语义。
在HEADER帧中。(注意不同的帧中,Flags不一样)
R
: 是一个保留的比特位。这个比特的语义没有定义,发送时它必须被设置为 (0x0), 接收时需要忽略。Frame Payload
: 是主体内容,由帧类型决定
SETTING 帧
SETTING帧只运行在 0 号流上。SETTING帧不是协商,而是通知。
帧类型
- SETTINGS_HEADER_TABLE_SIZE (0x1): 通知对端索引表的最大尺寸(单位字节,初始 4096 字节)用于解码header块的header压缩表的最大尺寸。
- SETTINGS_ENABLE_PUSH (0x2): Value设置为 0 时可禁用服务器推送功能,1 表示启用推送功能。如果禁用对端就不能发送PUSH_PROMISE 帧,如果客户端收到PUSH_PROMISE 就视为PROTOCOL_ERROR 的连接错误。
- SETTINGS_MAX_CONCURRENT_STREAMS (0x3): 告诉接收端允许的最大并发流数量。
- SETTINGS_INITIAL_WINDOW_SIZE (0x4): 声明发送端的窗口大小,用于Stream级别流控,初始值2^16-1 (65,535)
字节 - SETTINGS_MAX_FRAME_SIZE (0x5):设置帧的最大大小,初始值 2^14 (16,384)字节
- SETTINGS_MAX_HEADER_LIST_SIZE (0x6): 知会对端头部索引表的最大尺寸,单位字节,基于未压缩前的头部