php小编草莓在这里给大家带来关于"Go:不遵守 ResponseController 的截止日期"的介绍。在软件开发中,ResponseController 是一个常见的控制器,用于处理响应请求。然而,有时开发者在编写代码时可能会忽略对 ResponseController 的截止日期的遵守,这可能会导致一系列问题。本文将详细探讨这个问题,并提供解决方案,以确保代码的可靠性和稳定性。
问题内容
我有一些代码,如果写入时间太长,我会尝试取消写回客户端。我想我可以使用 http.responsecontroller 来实现此目的,因为它有一个 setwritedeadline 方法。
不幸的是,在下面的代码中,rw.write
在截止日期过后不会返回错误。
还有其他方法可以取消写入吗?
package main
import (
"log"
"net/http"
"time"
)
func main() {
http.handlefunc("/", func(rw http.responsewriter, r *http.request) {
log.println(r.method, r.url.path)
rc := http.newresponsecontroller(rw)
dl := time.now().add(3 * time.second)
if err := rc.setwritedeadline(dl); err != nil {
log.println(err)
return
}
log.println("write deadline:", dl)
var total int
for _, b := range []byte("what!\n") {
time.sleep(time.second)
n, err := rw.write([]byte{b})
if err != nil {
log.println(err)
return
}
total += n
log.println("bytes written", n)
}
log.println(r.method, r.url.path, "write total", total)
})
http.listenandserve(":8080", nil)
}
$ go run main.go
2023/04/26 12:24:40 get /
2023/04/26 12:24:40 write deadline: 2023-04-26 12:24:43.303884739 -0700 pdt m=+11.5891
16304
2023/04/26 12:24:41 bytes written 1
2023/04/26 12:24:42 bytes written 1
2023/04/26 12:24:43 bytes written 1
2023/04/26 12:24:44 bytes written 1
2023/04/26 12:24:45 bytes written 1
2023/04/26 12:24:46 bytes written 1
2023/04/26 12:24:46 get / write total 6
$ curl http://localhost:8080/
curl: (52) Empty reply from server
解决方法
setwritedeadline 文档说:
setwritedeadline 设置写入响应的截止日期。超过截止时间后写入响应正文不会阻塞,但如果数据已缓冲,则可能会成功。
问题中对响应编写器的写入成功,因为应用程序写入的少量数据被缓冲。
来自curl的“来自服务器的空回复”错误表明,当服务器从处理程序返回时将响应刷新到底层网络连接时,就遵守了截止日期。
使用 setwritedeadline 来防止客户端速度缓慢。
使用带有截止日期的上下文来限制服务器生成响应所用的时间:
65bd46fc4二月以上就是Go:不遵守 ResponseController 的截止日期的详细内容,更多请关注编程网其它相关文章!