重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要介绍golang中cpu的性能分析示例,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
成都创新互联公司专注骨干网络服务器租用10年,服务更有保障!服务器租用,南充服务器托管 成都服务器租用,成都服务器托管,骨干网络带宽,享受低延迟,高速访问。灵活、实现低成本的共享或公网数据中心高速带宽的专属高性能服务器。
(1)time指令(linux系统下)
time go run a.go
real:从程序开始到结束,实际上度过的时间
user:程序在用户态度过的时间
sys:程序在内核度过的时间
一般情况下,real>=user+sys
(2) /usr/bin/time 指令(linux系统下)
/usr/bin/time -v go run a.go
该指令下 可以看到 cpu占用率、 内存使用情况、 进程切换情况 、文件系统io、socket情况
(1)在程序中引入 _ "net/http/pprof" ,并开启pprof监听
import _
http.ListenAndServe("0.0.0.0:10000", nil)
程序结束
通过浏览器查看 CPU的信息和状态
http://127.0.0.1:10000/debug/pprof
注意,等程序运⾏⼀定时间,再点击profile⽂件⽣成(⾄少是30s)
(2)使用pprof
go tool pprof [binary] [profile] //binary二进制文件 profile 要分析的文件
top //查看当前profile文件的cpu使用率
flat 该函数⾃身代码的执⾏时⻓
flat% 该函数⾃身代码的执⾏时⻓占⽤CPU的耗时百分⽐
cum 代表的是该函数⾃身代码+所有调⽤的函数的执⾏时⻓
cum% 代表的是该函数⾃身代码+所有调⽤的函数的执⾏时⻓,占⽤CPU的总耗时百分⽐
sum% 每⼀⾏的flat%与上⾯所有⾏的flat%总和
(3)go tool pprof profile文件
启动要调试的程序,在另一个终端执行 go tool pprof http://localhost:10000/debug/pprof/profile?seconds=60
(4)可视化结构图
先在终端运行 go tool pprof [binary] [profile] ,然后输入web,浏览器会弹出一个可视化的图片。
以上是“golang中cpu的性能分析示例”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!