首页 > 技术文章 > gin异步协程

CJ-cooper 2021-10-11 15:41 原文

异步协程


package main
import (
    "gopkg.in/gin-gonic/gin.v1"
    "time"
    "log"
)


func main(){
    // only set in Production
    // gin.SetMode(gin.ReleaseMode)  

    router := gin.Default()
    router.GET("/sync", func(c *gin.Context) {
        time.Sleep(5 * time.Second)
        //先Sleep 5S ,Print 后  返回http响应
        log.Println("Done! in path" + c.Request.URL.Path)
    })

    router.GET("/async", func(c *gin.Context) {
        //先返回http响应

        // 异步 执行程序 Sleep 5S  后  Print 
        cCp := c.Copy()
        go func() {
            time.Sleep(5 * time.Second)
            log.Println("Done! in path" + cCp.Request.URL.Path)
        }()
    })
    router.Run(":8005")
}

在这里插入图片描述

推荐阅读