为了账号安全,请及时绑定邮箱和手机立即绑定

如何正确关闭请求并在后台继续处理它

如何正确关闭请求并在后台继续处理它

Go
饮歌长啸 2022-03-07 15:50:08
对于传入的 HTTP 请求,我必须使用202 Accepted状态码进行响应,同时继续在后台处理有效负载。例如,这就是我目前正在做的事情:package mainimport (    "fmt"    "log"    "net/http"    "time"    "github.com/nbari/violetear")func sleep() {    time.Sleep(3 * time.Second)    fmt.Println("done...")}func index(w http.ResponseWriter, r *http.Request) {    w.WriteHeader(http.StatusAccepted)    go sleep()}func main() {    router := violetear.New()    router.HandleFunc("*", index)    http.Handle("/", router)    log.Fatal(http.ListenAndServe(":8080", router))}基本上,在我刚刚使用的处理程序上,然后在 goroutine 中WriteHeader调用该函数:sleepfunc index(w http.ResponseWriter, r *http.Request) {    w.WriteHeader(http.StatusAccepted)    go sleep()}如果我想回复“200 OK”,我注意到我可以简单地返回,例如:func index(w http.ResponseWriter, r *http.Request) {    go sleep()    return}因此想知道我是否应该总是返回我想关闭:func index(w http.ResponseWriter, r *http.Request) {    w.WriteHeader(http.StatusAccepted)    go sleep()    return}或者只写标题然后调用 goroutine 就足够了。
查看完整描述

1 回答

?
小唯快跑啊

TA贡献1863条经验 获得超2个赞

从处理程序返回就足够了,并且是应该做的。引自http.Handler

返回请求完成的信号;在 ServeHTTP 调用完成之后或同时使用 ResponseWriter 或从 Request.Body 读取是无效的。

请注意,最后的return语句不是必需的,您可以简单地省略它。执行在其最后一条语句执行时从处理程序返回,执行不等待从函数启动的 goroutines 完成。(请注意,延迟语句会先执行,但这里没有。)

同样在返回时,如果未设置 HTTP 标头,200 OK将自动设置。因此,如果您愿意202 Accepted,以下是最低要求:

func index(w http.ResponseWriter, r *http.Request) {
    w.WriteHeader(http.StatusAccepted)
    go sleep()}

只需确保在从处理程序返回后不要在并发 goroutine 中使用http.ResponseWriterandhttpRequest值,因为它们可能会被重用,因此您甚至不应该尝试读取它们。


查看完整回答
反对 回复 2022-03-07
  • 1 回答
  • 0 关注
  • 338 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号