mirror of https://github.com/EasyDarwin/EasyDarwin
82 lines
1.8 KiB
Markdown
82 lines
1.8 KiB
Markdown
![]() |
# pprof
|
||
|
|
||
|
[data:image/s3,"s3://crabby-images/a413f/a413f52735a4052bc099561f44dc1c29e69ca332" alt="Build Status"](https://travis-ci.org/gin-contrib/pprof)
|
||
|
[data:image/s3,"s3://crabby-images/f2ae1/f2ae121c5771603462985063b745855964ee140a" alt="codecov"](https://codecov.io/gh/gin-contrib/pprof)
|
||
|
[data:image/s3,"s3://crabby-images/16c0a/16c0a09bf4b7e3dfa309eff842f05ad74c49ee8d" alt="Go Report Card"](https://goreportcard.com/report/github.com/gin-contrib/pprof)
|
||
|
[data:image/s3,"s3://crabby-images/668ce/668ce21860e8e4b4d8733aee28005959861d90d8" alt="GoDoc"](https://godoc.org/github.com/gin-contrib/pprof)
|
||
|
[data:image/s3,"s3://crabby-images/55d7b/55d7baa2b87b297b8fc1aec61f3df1ba76ba0e45" alt="Join the chat at https://gitter.im/gin-gonic/gin"](https://gitter.im/gin-gonic/gin)
|
||
|
|
||
|
gin pprof middleware
|
||
|
|
||
|
> Package pprof serves via its HTTP server runtime profiling data in the format expected by the pprof visualization tool.
|
||
|
|
||
|
## Usage
|
||
|
|
||
|
### Start using it
|
||
|
|
||
|
Download and install it:
|
||
|
|
||
|
```bash
|
||
|
$ go get github.com/gin-contrib/pprof
|
||
|
```
|
||
|
|
||
|
Import it in your code:
|
||
|
|
||
|
```go
|
||
|
import "github.com/gin-contrib/pprof"
|
||
|
```
|
||
|
|
||
|
### Example:
|
||
|
|
||
|
```go
|
||
|
package main
|
||
|
|
||
|
import (
|
||
|
"github.com/gin-contrib/pprof"
|
||
|
"github.com/gin-gonic/gin"
|
||
|
)
|
||
|
|
||
|
func main() {
|
||
|
router := gin.Default()
|
||
|
pprof.Register(router)
|
||
|
router.Run(":8080")
|
||
|
}
|
||
|
```
|
||
|
|
||
|
### change default path prefix:
|
||
|
|
||
|
```go
|
||
|
func main() {
|
||
|
router := gin.Default()
|
||
|
// default is "debug/pprof"
|
||
|
pprof.Register(router, "dev/pprof")
|
||
|
router.Run(":8080")
|
||
|
}
|
||
|
```
|
||
|
|
||
|
### Use the pprof tool
|
||
|
|
||
|
Then use the pprof tool to look at the heap profile:
|
||
|
|
||
|
```bash
|
||
|
go tool pprof http://localhost:8080/debug/pprof/heap
|
||
|
```
|
||
|
|
||
|
Or to look at a 30-second CPU profile:
|
||
|
|
||
|
```bash
|
||
|
go tool pprof http://localhost:8080/debug/pprof/profile
|
||
|
```
|
||
|
|
||
|
Or to look at the goroutine blocking profile, after calling runtime.SetBlockProfileRate in your program:
|
||
|
|
||
|
```bash
|
||
|
go tool pprof http://localhost:8080/debug/pprof/block
|
||
|
```
|
||
|
|
||
|
Or to collect a 5-second execution trace:
|
||
|
|
||
|
```bash
|
||
|
wget http://localhost:8080/debug/pprof/trace?seconds=5
|
||
|
```
|