【发布时间】:2021-08-24 07:38:23
【问题描述】:
我在码头上的服务器提供 API。 一些请求返回 200,但其他请求到具有不同参数的同一端点返回:
(failed)net::ERR_HTTP2_PROTOCOL_ERROR
它只出现在 Chrome 中。在 FF 中效果很好。
您知道可能是什么原因以及如何解决它吗?
【问题讨论】:
标签: google-chrome jetty http2
我在码头上的服务器提供 API。 一些请求返回 200,但其他请求到具有不同参数的同一端点返回:
(failed)net::ERR_HTTP2_PROTOCOL_ERROR
它只出现在 Chrome 中。在 FF 中效果很好。
您知道可能是什么原因以及如何解决它吗?
【问题讨论】:
标签: google-chrome jetty http2
您应该查看 Jetty 服务器调试日志以获取更多信息,或在此处报告以进行分析。
这些错误的一个原因可能是 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,这可能会导致此问题。我的队友确实卸载了那个补丁并为他修复了。
【讨论】: