对于传入的 HTTP 请求,我必须使用202 Accepted状态代码进行响应,同时继续在后台处理有效负载。例如,这就是我目前正在做的事情:
package main
import (
"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))
}
Run Code Online (Sandbox Code Playgroud)
基本上,在处理程序上我只使用,然后在 goroutine 中WriteHeader
调用该函数:sleep
func index(w http.ResponseWriter, r *http.Request) {
w.WriteHeader(http.StatusAccepted)
go sleep()
}
Run Code Online (Sandbox Code Playgroud)
如果我想回复“200 OK”,我注意到我可以简单地返回,例如:
func index(w http.ResponseWriter, r *http.Request) {
go sleep()
return
}
Run Code Online (Sandbox Code Playgroud)
因此想知道我是否应该总是返回我想关闭:
func index(w http.ResponseWriter, r *http.Request) {
w.WriteHeader(http.StatusAccepted)
go sleep()
return
}
Run Code Online (Sandbox Code Playgroud)
或者只需编写 header 并接下来调用 goroutine 就足够了。
从处理程序返回就足够了,也是应该做的。引用自http.Handler
:
返回信号表明请求已完成;在 ServeHTTP 调用完成之后或同时,使用 ResponseWriter 或从 Request.Body 读取是无效的。
请注意,最后的return
语句不是必需的,您可以简单地省略它。当执行最后一条语句时,执行从处理程序返回,执行不会等待从函数启动的 goroutine 完成。(请注意,延迟语句将在之前执行,但这里没有任何延迟语句。)
另外,返回时,如果未设置 HTTP 标头,200 OK
将自动设置。因此,如果您想要202 Accepted
,以下是最低要求:
func index(w http.ResponseWriter, r *http.Request) {
w.WriteHeader(http.StatusAccepted)
go sleep()
}
Run Code Online (Sandbox Code Playgroud)
只需确保从处理程序返回后,不要在并发 goroutine 中使用http.ResponseWriter
和值,因为它们可能会被重用,因此您甚至不应该尝试读取它们。httpRequest
归档时间: |
|
查看次数: |
5108 次 |
最近记录: |