gin中在中间件或handler中使用goroutine

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
package main
 
import (
    "fmt"
    "github.com/gin-gonic/gin"
    "log"
    "time"
)
 
func main() {
    // 当在中间件或handler启动新的goroutine时, 不能使用原始的上下文,必须使用只读的副本
    r := gin.Default()
    r.GET("/long_async", func(context *gin.Context) {
        // 创建在goroutine中使用的副本
        cpContext := context.Copy()
        go func() {
            time.Sleep(2 * time.Second)
            // 注意:使用的是复制的上下文cpContext,这一点很重要
            fmt.Println(cpContext.Request.URL.Path)
        }()
    })
    r.GET("/long_sync", func(context *gin.Context) {
        time.Sleep(2 * time.Second)
        // 因为没有使用goroutine,所以不需要拷贝上下文
        log.Println(context.Request.URL.Path)
    })
    r.Run()
}

 

在中间件中使用goroutine

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
func main() {
    // 在中间件中使用goroutine时,必须使用上下文的只读副本
    router := gin.Default()
    router.Use(func(context *gin.Context) {
        cpContext := context.Copy()
        go func() {
            log.Println("中间件执行了")
            log.Println(cpContext.Request.URL.Path)
        }()
    })
    router.GET("/json", func(context *gin.Context) {
        context.String(200, "OK")
    })
    router.Run()
}

 

 

posted @   专职  阅读(452)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示