卓越飞翔博客卓越飞翔博客

卓越飞翔 - 您值得收藏的技术分享站
技术文章34759本站已运行393

Go:不遵守 ResponseController 的截止日期

go:不遵守 responsecontroller 的截止日期

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 中停止监听服务器
下一篇: 返回列表
留言与评论(共有 0 条评论)
   
验证码:
隐藏边栏