【博客543】golang pprof性能调试:寻找cpu瓶颈
创始人
2024-02-23 05:52:05
0

golang pprof性能调试:寻找cpu瓶颈

1、引入pprof进行性能调试

在代码中加入:

import _ "net/http/pprof"go func() {http.ListenAndServe("0.0.0.0:8899", nil)
}()

示例:为冒泡排序加入pprof debug

package mainimport ("math/rand""net/http"_ "net/http/pprof""time"
)func generate(n int) []int {rand.Seed(time.Now().UnixNano())nums := make([]int, 0)for i := 0; i < n; i++ {nums = append(nums, rand.Int())}return nums
}
func bubbleSort(nums []int) {for i := 0; i < len(nums); i++ {for j := 1; j < len(nums)-i; j++ {if nums[j] < nums[j-1] {nums[j], nums[j-1] = nums[j-1], nums[j]}}}
}func main() {go func() {http.ListenAndServe("0.0.0.0:8899", nil)}()for {n := 10for i := 0; i < 5; i++ {nums := generate(n)bubbleSort(nums)n *= 10}}
}

2、pprof命令行交互式查看程序最消耗cpu的地方

1、启动上述程序:

go run main.go

2、访问pprof暴露的cpu debug api接口,收集30s内的cpu数据:

go tool pprof http://localhost:8899/debug/pprof/profile\?seconds\=30

3、在交互命令中,使用top,list来查看最消耗cpu的地方

go tool pprof http://localhost:8899/debug/pprof/profile\?seconds\=30
Fetching profile over HTTP from http://localhost:8899/debug/pprof/profile?seconds=30
Saved profile in /Users/zejia.lu/pprof/pprof.samples.cpu.003.pb.gz
Type: cpu
Time: Nov 27, 2022 at 12:09pm (CST)
Duration: 30.19s, Total samples = 26.13s (86.56%)
Entering interactive mode (type "help" for commands, "o" for options)
(pprof) top
Showing nodes accounting for 26.06s, 99.73% of 26.13s total
Dropped 18 nodes (cum <= 0.13s)flat  flat%   sum%        cum   cum%24.57s 94.03% 94.03%     26.06s 99.73%  main.bubbleSort (inline)1.49s  5.70% 99.73%      1.49s  5.70%  runtime.asyncPreempt0     0% 99.73%     26.06s 99.73%  main.main0     0% 99.73%     26.06s 99.73%  runtime.main
(pprof) list main.bubbleSort
Total: 26.13s
ROUTINE ======================== main.bubbleSort in /Users/zejia.lu/go_pprof/main.go24.57s     26.06s (flat, cum) 99.73% of Total.          .     15:	}.          .     16:	return nums.          .     17:}.          .     18:func bubbleSort(nums []int) {.          .     19:	for i := 0; i < len(nums); i++ {12.41s     13.31s     20:		for j := 1; j < len(nums)-i; j++ {4.33s      4.92s     21:			if nums[j] < nums[j-1] {7.83s      7.83s     22:				nums[j], nums[j-1] = nums[j-1], nums[j].          .     23:			}.          .     24:		}.          .     25:	}.          .     26:}.          .     27:

4、输出列解析

flat	当前函数占用 cpu 耗时
flat %	当前函数占用 cpu 耗时百分比
sum%	函数占用 cpu 时间累积占比,从小到大一直累积到 100%
cum	    当前函数加上调用当前函数的函数占用 cpu 的总耗时
%cum	当前函数加上调用当前函数的函数占用 cpu 的总耗时占比

5、结果分析

我们可以看到最消耗cpu的函数:
24.57s 94.03% 94.03%     26.06s 99.73%  main.bubbleSort (inline)我们可以看到这个函数里cpu消耗在哪里:
12.41s     13.31s     20:		for j := 1; j < len(nums)-i; j++ {
4.33s      4.92s     21:			if nums[j] < nums[j-1] {
7.83s      7.83s     22:				nums[j], nums[j-1] = nums[j-1], nums[j]

3、pprof ui方式查看程序最消耗cpu的地方

1、调试时指定通过ui方式查看,ui地址为8888端口,要调试的服务暴露的pprof端口为8899:

go tool pprof -http=":8888" http://localhost:8899/debug/pprof/profile

2、访问8888端口查看ui界面进行可视化调试:

查看最消耗cpu的地方:
在这里插入图片描述
在这里插入图片描述

4、pprof ui方式查看cpu消耗拓扑图

在这里插入图片描述
在这里插入图片描述

5、pprof ui方式查看cpu消耗火焰图

在这里插入图片描述
在这里插入图片描述

生成追踪图和火焰图需要安装graphviz

brew install graphviz

常用命令

// 查看cpu消耗前20的函数调用
top 20// 查看累计cpu消耗前20的函数调用
top -cum 20// 查看代码符号附近的cpu占用情况。其中代码符号类似于c++的函数符号表,可以简单理解成函数名
list "代码符号"

相关内容

热门资讯

幼儿园大班毕业生家长会主持词 幼儿园大班毕业生家长会主持词(精选7篇)  主持词需要富有情感,充满热情,才能有效地吸引到观众。在各...
幼儿园六一文艺汇演主持词   1:尊敬的各位家长、  2:亲爱的小朋友们,  3:亲爱的爸爸妈妈、叔叔阿姨们  4:敬爱的老师...
同学聚会祝酒词 同学聚会祝酒词高中同学聚会祝酒词(1):斗转星移,岁月如歌,转眼我们从古龙中学毕业已经9多年了。9年...
台词经典语录 台词经典语录15篇  无论是在学校还是在社会中,许多人对一些广为流传的语录都不陌生吧,语录具有短小简...
幼儿园元旦晚会园长的经典致辞 幼儿园元旦晚会园长的经典致辞(精选5篇)  在平时的学习、工作或生活中,大家或多或少都用到过致辞吧,...
婚礼男方家长致辞 婚礼男方家长致辞通用15篇  无论在学习、工作或是生活中,大家都不可避免地会接触到致辞吧,致辞具有“...
学校班级元旦晚会主持稿 学校班级元旦晚会主持稿  导语:在学校召开元旦晚会的时候,通常要用到主持词的。接下来小编整理了学校班...
新郎迎娶新娘主持词 新郎迎娶新娘是一生中最浪漫的事情之一,那么都有什么好的主持词呢?以下是PINCAI小编整理的关于主持...
公司员工大会主持稿 公司员工大会主持稿  在现在的社会生活中,需要使用主持稿的情况越来越多,主持稿一般是由主持人根据场景...
开业的致辞 开业的致辞15篇  在日常的学习、工作、生活中,大家都对致辞很是熟悉吧,致辞是指在举行会议或某种仪式...
毕业聚餐主持词 毕业聚餐主持词  主持词是主持人在节目进行过程中用于串联节目的串联词。在当今中国社会,主持人在活动中...
女娲传说之灵珠经典台词 女娲传说之灵珠经典台词15句  你们根本不懂爱,你们的爱太过自私,不择手段。——仙乐  你放心,我不...
青春演讲比赛主持词 青春演讲比赛主持词  主持:  男——李勇  女——张雨  女:我与祖国共奋进男:我为崛起献青春。 ...
年会赞助商致辞 年会赞助商致辞(精选5篇)  在日常的学习、工作、生活中,要用到致辞的情况还是蛮多的,致辞具有很强的...
培训会主持词 培训会主持词(精选10篇)  在日常中,大家总免不了要培训及会议吧,那么你知道主持词怎么写吗?下面是...
电影《三少爷的剑》经典台词 电影《三少爷的剑》经典台词精选  1. 冷风如刀,大地荒漠,苍天无情。  2. 这世上永远有两种人,...
《十六个夏天》的经典台词 《十六个夏天》的经典台词大全  1.就说我不是他的收藏品,乱说什么啊!  2.说话冲的人,心里都是软...
80岁生日宴会致辞 80岁生日宴会致辞(精选11篇)  在学习、工作或生活中,大家都不可避免地会接触到致辞吧,致辞具有有...
婚宴长辈证婚人致辞 婚宴长辈证婚人致辞  在平日的学习、工作和生活里,大家总少不了要接触或使用致辞吧,致辞受场合、事件的...
元旦舞会主持词 元旦舞会主持词(精选7篇)  主持词要尽量增加文化内涵、寓教于乐,不断提高观众的文化知识和素养。在人...