golang中cpu的性能分析示例-创新互联

这篇文章主要介绍golang中cpu的性能分析示例,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

尼木ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为创新互联的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:18980820575(备注:SSL证书合作)期待与您的合作!

一、分析程序的运行时间

(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情况

二.golang下cpu性能分析

(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的性能分析示例”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!

新闻标题:golang中cpu的性能分析示例-创新互联
网页路径:https://www.cdcxhl.com/article6/dojeig.html

成都网站建设公司_创新互联,为您提供软件开发商城网站网站排名外贸建站移动网站建设全网营销推广

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

h5响应式网站建设