Error (failed)net::ERR_HTTP2_PROTOCOL_ERROR 仅在 Chrome 中随机发生

问题描述

我在码头上的服务器提供 API。 一些请求返回 200,但其他对同一端点的具有不同参数的请求返回:

(Failed)net::ERR_HTTP2_PROTOCOL_ERROR

它仅在 Chrome 中发生。在 FF 中它运行良好。

您知道可能是什么原因以及如何解决吗?

解决方法

您应该查看 Jetty 服务器 DEBUG 日志以获取更多信息,或在此处报告以供分析。

这些错误的一个原因可能是 Jetty 使用默认为 20 的参数 jetty.http2.rateControl.maxEventsPerSecond 来防止 these vulnerabilities

不同的浏览器向服务器发送不同的帧;特别是,Chrome 会向服务器发送许多 PRIORITY 帧,对于具有大量资源的页面,可能会触发 maxEventsPerSecond=20 阈值。

您可能希望将此参数配置为更高的值,例如 50,然后查看错误是否仍然发生。

如果你使用 Jetty 嵌入式,你想使用类似这样的代码:

HTTP2ServerConnectionFactory http2 = ...;
http2.setRateControlFactory(endPoint -> new WindowRateControl.Factory(50));
,

当我遇到这个错误时,我还认为它只是在 Chrome 中 - 当我尝试了几次 FF 时,它似乎有效。但还有几次表明,FF 中的随机性与 Chrome 中的相同。

有一些讨论here

您可能需要检查您的 Windows 更新是否没有拉取 KB5003637,这可能会导致此问题。我的队友确实卸载了那个补丁并为他修复了。