当发送到云运行服务的HTTP请求被发起服务取消时,被取消/关闭的连接不被传播到正在云运行容器内被服务的请求。
示例代码:
package main
import (
"log"
"net/http"
"os"
"time"
)
func main() {
port := os.Getenv("PORT")
if port == "" {
port = "8080"
}
http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
ctx := r.Context()
select {
case <-ctx.Done():
log.Printf("context cancelled")
case <-time.After(time.Minute):
w.Write([]byte("OK"))
log.Printf("request completed. path=%s", r.URL.Path)
}
})
log.Fatal(http.ListenAndServe(":"+port, nil))
}
在本地运行此代码时,发送到http://localhost:8080然后使用ctrl-c取消的curl请求将在日志中显示为“上下文已取消”。在云运行中部署并取消的相同请求,在日志中会在1分钟后显示为请求成功。
https://stackoverflow.com/questions/56431629
复制相似问题