作者:顾欣
Triple 是 Dubbo 3 提出的基于 HTTP2 的开放协议, 旨在解决 Dubbo 2 私有协议带来的互通性问题。 Triple 基于 HTTP/2 定制自己的流控,支持通过特定的异常通知客户端业务层服务端负载高情况, 保护了服务端被大流量击垮,提高系统高可用能力。
一、流控反压现状
客户端和服务器端在接收数据的时候有一个缓冲区来临时存储数据, 但是缓冲区的大小是有限制的,所以有可能会出现缓冲区溢出的情况, HTTP 通过流控保护数据溢出丢失风险。
1、HTTP/1 流控
在 HTTP/1.1 中,流量的控制依赖的是底层TCP协议,在客户端和服务器端建立连接的时候, 会使用系统默认的设置来建立缓冲区。在数据进行通信的时候,会告诉对方它的接收窗口的大小, 这个接收窗口就是缓冲区中剩余的可用空间。如果接收窗口大小为零,则说明接收方缓冲区已满, 则发送方将不再发送数据,直到客户端清除其内部缓冲区,然后请求恢复数据传输。
2、HTTP/2 流控
HTTP/2 使用了多路复用机制,一个TCP连接可以有多个 HTTP/2 连接, 故在 HTTP/2 中,有更加精细的流控制机制,允许服务端实现自己数据流和连接级的流控制。 服务端与客户端初次见了连接时,会通过发送 HTTP/2 SettingsFrame
设置初始化的流控窗口大小, 用于 Stream
级别流控,默认为 65,535 字节。 定好流控窗口后,每次客户端发送数据就会减少流控窗口的大小, 服务端收到数据后会发送窗口