对于传入的 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值,因为它们可能会被重用,因此您甚至不应该尝试读取它们。
- 1 回答
- 0 关注
- 338 浏览
添加回答
举报
0/150
提交
取消
