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 响应结构的传输。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
【小浪云服务商 - 服务器12元起 - 挂机宝5元起】
THE END
暂无评论内容