当前位置: > > > > Go:不遵守 ResponseController 的截止日期
来源:stackoverflow
2024-04-24 21:36:35
0浏览
收藏
Golang不知道大家是否熟悉?今天我将给大家介绍《Go:不遵守 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 设置写入响应的截止日期。超过截止时间后写入响应正文不会阻塞,但如果数据已缓冲,则可能会成功。
问题中对响应编写器的写入成功,因为应用程序写入的少量数据被缓冲。
来自curl的“来自服务器的空回复”错误表明,当服务器从处理程序返回时将响应刷新到底层网络连接时,就遵守了截止日期。
使用 来防止客户端速度缓慢。
使用来限制服务器生成响应所用的时间:
65bd46fc4二月
今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注公众号,一起学习编程~