Post

pporf使用

下载pporf:

1
2
3
4
|端点|	debug=0|	debug=1|	debug=2|
|/debug/pprof/goroutine	| 二进制(pprof 分析) |	简要 Goroutine 堆栈 |	完整 Goroutine 堆栈
|/debug/pprof/heap	| 二进制(pprof 分析) |	内存聚合统计 |	详细堆内存对象
|/debug/pprof/profile	| 二进制(pprof 分析) |	文本 CPU 报告 |无

cpu:export PPROF_TMPDIR=/home/foo; go tool pprof http://127.0.0.1:31777/debug/pprof/profile?second=30

内存:

  • 方式1: export PPROF_TMPDIR=/home/foo; go tool pprof --inuse_space http://127.0.0.1:31777/debug/pprof/heap?second=30
  • 方式2: curl -GET --unix-socket ./debug.sock "http://localhost/debug/pprof/heap?debuge=0&seconds=30" -o heap_30s.pprof

goroutine

  • 下载pb.gz文件并命令行分析:export PPROF_TMPDIR=./; go tool pprof http://localhost:3/debug/pprof/goroutine
  • 下载可视化文本文件:curl http://localhost:3/debug/pprof/goroutine?debug=1 > goroutine.txt
    • debug=1: 可视化文本格式

trace: curl -s http://localhost:1777/debug/pprof/trace?seconds=5 > server-trace.pprof

分析pporf:

cpu:go tool pprof --http=0.0.0.0:9998 pprof.xxx.cpu.008.pb.gz

内存:go tool pprof --http=0.0.0.0:9999 pprof.xxxx.008.pb.gz

goroutine: go tool pprof -http=:8080 pprof.xx.goroutine.xxx.pb.gz

trace: go tool trace server-trace.pprof

pool池化对象,getslow但不newobject

img.png

  • 需要跨P获取对象
  • 解决:在同一个G中Get\Put对象
This post is licensed under CC BY 4.0 by the author.