马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?立即注册
x
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企服之家,中国第一个企服评测及商务社交产业平台。 |