深入HTTP2 (帧格式)

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不一样)

    HEADER 中的 Flags

  • R: 是一个保留的比特位。这个比特的语义没有定义,发送时它必须被设置为 (0x0), 接收时需要忽略。

  • Frame Payload : 是主体内容,由帧类型决定

SETTING 帧

SETTING帧只运行在 0 号流上。SETTING帧不是协商,而是通知。


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): 知会对端头部索引表的最大尺寸,单位字节,基于未压缩前的头部

你可能感兴趣的:(深入HTTP2 (帧格式))