當(dāng)在中間件或 handler 中啟動(dòng)新的 Goroutine 時(shí),不能使用原始的上下文,必須使用只讀副本。
package main
import (
"github.com/gin-gonic/gin"
"log"
"time"
)
func main() {
r := gin.Default()
r.GET("/test1", func(c *gin.Context) {
// 拷貝一份副本在Goroutine中使用
tmp := c.Copy()
go func() {
time.Sleep(5 * time.Second)
// 這里使用的是值拷貝的tmp
log.Println("test1已完成,路徑是:" + tmp.Request.URL.Path)
}()
})
r.GET("/test2", func(c *gin.Context) {
time.Sleep(5 * time.Second)
// 因?yàn)闆]有使用 goroutine,不需要拷貝上下文
log.Println("test2已完成,路徑是:" + c.Request.URL.Path)
})
r.Run()
}
以上代碼執(zhí)行結(jié)果如下
更多建議: