Go 中 http.ResponseWriter 延迟发送问题:为什么在返回结果后其他耗时操作会延迟响应?

go 中 http.responsewriter 延迟发送问题:为什么在返回结果后其他耗时操作会延迟响应?

go 中 http.responsewriter 延迟发送问题解析

在使用 http.responsewriter 时,开发者有时会发现,在返回结果后其他耗时的操作会延迟响应发送。本文将分析此问题背后的原因。

问题

  • 服务端代码在 arm 架构上运行,执行以下函数:
func exampleHandler(w http.ResponseWriter, r *http.Request) {
    fmt.Fprintf(w, "example handler")
    md5BigFile(); // 耗时约 8 秒
}
  • 在返回结果后,函数调用了一个 cpu 密集型函数 md5bigfile()。
  • 客户端观察到在收到字符串 "example handler" 之前需要等待大约 8 秒。如果注释掉 md5bigfile() 函数,则问题消失。

解答

http 协议不是一个流,而是由明确结束标志的完整结构。http 服务器仅在处理程序函数返回时才认为发送已结束。

  • 作为客户端,即使提前收到 "example handler",它也不会立即返回,因为它知道返回尚未结束。
  • responsewriter 不会直接写入网络连接,而是构建一个完整的 http 响应结构,然后再写入连接。

在这种情况下,http 响应结构的构建被 md5bigfile() 函数延迟,导致客户端延迟收到完整响应。

虽然 go 默认启用 nodelay,但它仅适用于 tcp 连接,而不适用于 http 响应结构的传输。

以上就是Go 中 http.ResponseWriter 延迟发送问题:为什么在返回结果后其他耗时操作会延迟响应?的详细内容,更多请关注其它相关文章!