问题描述
我在码头上的服务器提供 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,这可能会导致此问题。我的队友确实卸载了那个补丁并为他修复了。