万有斥力 发表于 2024-8-13 23:46:04

zdpgo_gin_pprof 为 zdpgo_gin 框架提供的pprof性能分析工具

zdpgo_gin_pprof

为zdpgo_gin框架提供的pprof性能分析工具
安装

go get github.com/zhangdapeng520/zdpgo_gin_pprof
利用教程

默认配置

package main

import (
        gin "github.com/zhangdapeng520/zdpgo_gin"
        pprof "github.com/zhangdapeng520/zdpgo_gin_pprof"
)

func main() {
        router := gin.Default()
        pprof.Register(router)
        router.Run(":8080")
}
自界说配置

package main

import (
        "net/http"

        gin "github.com/zhangdapeng520/zdpgo_gin"
        pprof "github.com/zhangdapeng520/zdpgo_gin_pprof"
)

func main() {
        router := gin.Default()
        adminGroup := router.Group("/admin", func(c *gin.Context) {
                if c.Request.Header.Get("Authorization") != "foobar" {
                        c.AbortWithStatus(http.StatusForbidden)
                        return
                }
                c.Next()
        })
        pprof.RouteRegister(adminGroup, "pprof")
        router.Run(":8080")
}
浏览器访问如下页面

查看文字版pprof信息
http://localhost:8080/debug/pprof/
图形化查看:
go tool pprof -http="127.0.0.1:8089" http://127.0.0.1:8080/debug/pprof/goroutine
必要安装:https://graphviz.org/download/
参数说明



[*]allocs:内存分配,历史累计
[*]block:导致阻塞的堆栈记录,历史累计
[*]cmdline:当出息序命令行完整调用路径
[*]goroutine:当出息序所有goroutine堆栈信息,及时变化
[*]heap:活动对象内存分配情况,及时变化
[*]mutex:锁竞争记录,历史累计
[*]profile:cpu利用情况
[*]threadcreate:新线程创建情况
[*]trace:当出息序执行链路
[*]flat:当前函数的数据,不含调用其他函数
[*]flat%:当前函数分配占比
[*]sum%:本身和前面所有的flat%累积值
[*]cum:当前函数及当前函数调用其他函数分配总和
[*]cum%:当前函数及当前函数调用其他函数分配总和占比
利用 go tool

利用pprof工具查看堆配置文件:
go tool pprof http://localhost:8080/debug/pprof/heap
大概看看30秒的CPU配置文件:
go tool pprof http://localhost:8080/debug/pprof/profile
大概在调用runtime之后查看运行例程阻塞配置文件
go tool pprof http://localhost:8080/debug/pprof/block
大概收集5秒的执行跟踪:
wget http://localhost:8080/debug/pprof/trace?seconds=5
版本历史

v0.1.0



[*]基础代码

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: zdpgo_gin_pprof 为 zdpgo_gin 框架提供的pprof性能分析工具