HTTP2 中的 RST_STREAM 帧

Posted

技术标签:

【中文标题】HTTP2 中的 RST_STREAM 帧【英文标题】:RST_STREAM frame in HTTP2 【发布时间】:2015-04-28 11:26:09 【问题描述】:

我了解了 http2 RST_STREAM 中的新功能:

HTTP/2 添加 RST_STREAM 帧以允许客户端改变主意; 如果浏览器离开页面,或者用户取消了 下载,它可以避免必须打开新连接而不会浪费 所有带宽。

如何做到这一点?浏览器如何做到这一点?代码有什么变化吗?

【问题讨论】:

【参考方案1】:

浏览器发起一个请求,然后改变主意,要么让用户离开,要么取消。

在 HTTP/1.1 中,避免下载响应内容的唯一选择是关闭连接,因为客户端无法将这种中止请求的意图传达给服务器。关闭连接才是王道。

在 HTTP/2 中,如果客户端想要中止请求,它会发送一个 RST_STREAM。当服务器收到 RST_STREAM 时,它将停止向客户端发送 DATA 帧,从而停止响应(或下载)。 该连接仍可用于其他请求,并且与已中止的请求/响应并发的请求/响应可能会继续进行。

通常情况下,应用程序不需要做任何事情并且不知道 RST_STREAM,这一切都由浏览器和服务器实现完成。

有可能当 RST_STREAM 从客户端传输到服务器时,请求的全部内容都在传输中,将到达客户端,客户端将丢弃它。 但是,对于较大的响应内容,发送一个 RST_STREAM 可能有很大的机会在整个响应内容发送之前到达服务器,因此可以节省带宽。

【讨论】:

以上是关于HTTP2 中的 RST_STREAM 帧的主要内容,如果未能解决你的问题,请参考以下文章

Netty HTTP2 帧转发/代理 - 管道配置问题

http2.0

http2新特性

HTTP 2.0与OkHttp

使用 ffmpeg 获取帧数

Http2