Are you sure you want to delete this task? Once this task is deleted, it cannot be recovered.
|
|
6 years ago | |
|---|---|---|
| .. | ||
| .gitignore | 6 years ago | |
| .travis.yml | 6 years ago | |
| LICENSE | 6 years ago | |
| README.md | 6 years ago | |
| go.mod | 6 years ago | |
| go.sum | 6 years ago | |
| pprof.go | 6 years ago | |
gin pprof middleware
Package pprof serves via its HTTP server runtime profiling data in the format expected by the pprof visualization tool.
Download and install it:
go get github.com/gin-contrib/pprof
Import it in your code:
import "github.com/gin-contrib/pprof"
package main
import (
"github.com/gin-contrib/pprof"
"github.com/gin-gonic/gin"
)
func main() {
router := gin.Default()
pprof.Register(router)
router.Run(":8080")
}
func main() {
router := gin.Default()
// default is "debug/pprof"
pprof.Register(router, "dev/pprof")
router.Run(":8080")
}
Then use the pprof tool to look at the heap profile:
go tool pprof http://localhost:8080/debug/pprof/heap
Or to look at a 30-second CPU profile:
go tool pprof http://localhost:8080/debug/pprof/profile
Or to look at the goroutine blocking profile, after calling runtime.SetBlockProfileRate in your program:
go tool pprof http://localhost:8080/debug/pprof/block
Or to collect a 5-second execution trace:
wget http://localhost:8080/debug/pprof/trace?seconds=5
类似 Grafana 可接入多种数据源,Grafana 擅长可视化,夜莺擅长告警管理
Go SQL Text Python PLSQL other