V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
richzhu
V2EX  ›  Go 编程语言

Gin 启动之后, 路由后面的 Handlers 数量是什么意思

  •  
  •   richzhu · 2020-09-22 16:41:58 +08:00 · 1413 次点击
    这是一个创建于 1523 天前的主题,其中的信息可能已经有所发展或是发生改变。

    Handler 一直都是 4

    大佬们好,用 Gin 以来一直有个问题,每次等到项目启动之后,每一条路由后面都有一个 (数量 Handlers )的显示,并且数量是 4, 如下图: wOnMkQ.png

    Handler 变成 1

    问题发生于昨天,没想到这个项目越来越大,导致路由太多,就参照网上一个人的文章,把路由拆分了。 没想到,拆分后,所有的 Handlers 都变成了 1,如下图: wOnQYj.png

    想问一下各位大佬,这样的话,会不会对我的项目性能产生影响~~~

    顺便奉劝大家,不要随便相信网上的文章 T_T

    拆分方式

    拆分路由器的方式,如下图:

    wOuXqK.png

    4 条回复    2020-09-24 10:25:01 +08:00
    labulaka521
        1
    labulaka521  
       2020-09-23 10:04:22 +08:00
    应该是你的中间件数量+你的业务处理函数(1)
    也就是 RouterGroup 这个结构体的 Handlers 参数
    可以看看 gin 所使用的 httprouter
    richzhu
        2
    richzhu  
    OP
       2020-09-23 11:36:35 +08:00
    @labulaka521 中间件一直都只有 1 个呢,拆分之前是 4,拆分后就变成 1 了,请问这个从 4 变成了 1,对性能有影响嘛?
    Abirdcfly
        3
    Abirdcfly  
       2020-09-24 09:35:04 +08:00   ❤️ 1
    显示这个部分在 debugPrintRoute 函数
    ````
    func debugPrintRoute( httpMethod, absolutePath string, handlers HandlersChain) {
    if IsDebugging() {
    nuHandlers := len(handlers)
    for _, h := range handlers{ //
    debugPrint(" %s", nameOfFunction(h)) //这两行是我加的。看一下是啥就知道这 4 个是什么 handler 了。
    }
    handlerName := nameOfFunction(handlers.Last())
    if DebugPrintRouteFunc == nil {
    debugPrint("%-6s %-25s --> %s (%d handlers)\n", httpMethod, absolutePath, handlerName, nuHandlers)
    } else {
    DebugPrintRouteFunc( httpMethod, absolutePath, handlerName, nuHandlers)
    }
    }
    }
    ````

    我这里除去那个业务逻辑函数外,剩下的 3 个 handler 是
    github.com/gin-gonic/gin.LoggerWithConfig.func1
    github.com/gin-gonic/gin.RecoveryWithWriter.func1
    github.com/gin-contrib/cors.New.func1
    richzhu
        4
    richzhu  
    OP
       2020-09-24 10:25:01 +08:00
    @Abirdcfly 真大佬!疑惑解决了~ 非常感谢
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2667 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 05:38 · PVG 13:38 · LAX 21:38 · JFK 00:38
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.