Go工具(四):性能调试利器pprof(三)
文章目录
【注意】最后更新于 June 18, 2023,文中内容可能已过时,请谨慎使用。
1. trace说明
在pprof
的分析中,能够知道一段时间内的CPU
占用、内存分配、协程堆栈信息。这些信息都是一段时间内数据的汇总,但是它们并没有提供整个周期内发生的事件,例如指定的Goroutines
何时执行、执行了多长时间、什么时候陷入了堵塞、什么时候解除了堵塞、GC
如何影响单个Goroutine
的执行、STW
中断花费的时间是否太长等。这就是在Go1.5之后推出的trace
工具的强大之处,它提供了指定时间内程序发生的事件的完整信息,这些事件信息包括:
- 协程的创建、开始和结束。
- 协程的堵塞——系统调用、通道、锁。
- 网络I/O相关事件。
- 系统调用事件。
- 垃圾回收相关事件。
2. 收集trace样本
收集trace
文件的方式和收集pprof
特征文件的方式非常相似,有两种主要的方式
2.1 调用runtime/trace
包
|
|
2.2 调用net/http/pprof
net/http/pprof
库中集成了trace
的接口,下例获取30s
内的trace
事件并存储到trace.out
文件中。
|
|
2.3 在单元测试中使用-trace
|
|
3. 分析trace样本
分析
trace
样本,语法格式:go tool trace trace文件
3.1 第一步: 分析文件
|
|
3.2 第二步:在浏览器中打开
分析维度说明
View trace
:查看跟踪Goroutine analysis
:Goroutine
分析Network blocking profile
:网络阻塞概况Synchronization blocking profile
:同步阻塞概况Syscall blocking profile
:系统调用阻塞概况Scheduler latency profile
:调度延迟概况User defined tasks
:用户自定义任务User defined regions
:用户自定义区域Minimum mutator utilization
:最低 Mutator 利用率
4. View trace
查看跟踪
4.1 数据栏总览
含义说明:
- 时间线: 显示执行的时间,上图可以看出程序整体运行时间在
0s~20s
之间,可以用过放大查看具体某个时间点,运行情况。 Goroutines
: 显示在执行期间的每个Goroutine
运行阶段有多少个协程在运行,其包含 GC 等待(GCWaiting
)、可运行(Runnable
)、运行中(Running
)这三种状态。- 堆内存:包含当前堆使用量(
Allocated
)和下一次垃圾回收的目标大小(NextGC
)统计。 - 系统线程:显示在执行期间有多少个线程在运行,其包含正在调用
Syscall(InSyscall)
、运行中(Running
)这两种状态。 GC
: 执行垃圾回收的次数和具体时间点,由上图可以看出每次执行GC时,堆内存都会下降。- 逻辑处理器: 默认显示系统核心数量,可以通过
runtime.GOMAXPROCS(n)
来控制数量。
快捷键:
w(放大)、s(缩小)、a(左移)、d(右移)
4.2 某一时刻协程整体运行情况
由上图可以看出,这个时刻(
946.662607
): 运行中的协程数量为2、可运行的协程数量为1、等待GC的协程为0
4.3 某一时刻堆内存
4.4 某一时刻系统线程
4.5 查看垃圾回收
1.单个垃圾回收
2.查看多个垃圾回收
选中多个垃圾回收,则可查看多个垃圾回收信息
3.部分协程功能说明
-
proc start
: 代表启动新线程或从系统调用恢复。 -
proc stop
: 代表线程在系统调用中被阻塞或线程退出。 -
GC(dedicated、fractional、idle)
:在标记阶段GC
分为三种不同的mark worker
模式; 它们代表着不同的专注程度,其中dedicated
模式最专注,是完整的 GC 回收行为,fractional
只会干部分的 GC 行为,idle
最轻松。 -
MARK ASSIST
: 在分配内存过程中重新标记内存(mark the memory
)的goroutine -
STW (sweep termination)
: 代表STW
扫描阶段终止。 -
STW (mark termination)
: 代表STW
标记阶段终止。 -
runtime.gcBgMarkWorker
: 帮助标记内存的专用后台goroutine -
runtime.bgsweep
: 执行垃圾清理的goroutine。 -
runtime.bgscavenge
: gc碎片清理的goroutine。 -
syscall
: 代表goroutine在进行系统调用。 -
sysexit
: 代表goroutine
在syscall
中被取消或阻塞。
4.6 查看具体协程运行信息
含义说明:
字段名 | 说明 |
---|---|
Start |
开始时间 |
Wall Duration |
持续时间 |
Self Time |
执行时间 |
Start Stack Trace |
开始时的堆栈信息 |
End Stack Trace |
结束时的堆栈信息 |
Incoming flow |
输入流 |
Outgoing flow |
输出流 |
Preceding events |
之前的事件 |
Following events |
之后的事件 |
All connected |
所有连接的事件 |
5. 协程分析(Goroutine analysis
)
5.1 详情查看
5.2 字段说明
名称 | 含义 | 耗时 |
---|---|---|
Execution Time |
执行时间 | 151µs |
Network Wait Time |
网络等待时间 | 0ns |
Sync Block Time |
同步阻塞时间 | 19s |
Blocking Syscall Time |
调用阻塞时间 | 0ns |
Scheduler Wait Time |
调度等待时间 | 24µs |
GC Sweeping |
GC 清扫 | 0ns |
GC Pause |
GC 暂停 | 12ms |
6.用户自定义任务
6.1 代码详情
|
|
6.2 查看详情
文章作者 Learn Go
上次更新 2023-06-18