使用Golang进行性能分析(Profiling)

发布时间:2017-7-9 7:26:43编辑:www.fx114.net 分享查询网我要评论
本篇文章主要介绍了"使用Golang进行性能分析(Profiling) ",主要涉及到使用Golang进行性能分析(Profiling) 方面的内容,对于使用Golang进行性能分析(Profiling) 感兴趣的同学可以参考一下。

使用Golang进行性能分析(Profiling)

转自:http://www.cppblog.com/sunicdavy/archive/2015/04/11/210308.html

本文介绍游戏服务器的性能分析, web服务器性能分析不在本文分析范畴之内

Golang编写的服务器可以方便的通过内建性能分析, 输出图表仔细查找原因, 非常的方便, 如下图

1. 获取一个性能分析的封装库

   go get github.com/davecheney/profile
   2. 在工程内import这个组件    

3. 在main中添加启动和停止入口

func main() {
    defer profile.Start(profile.CPUProfile).Stop()
 
    // ... your main code here ...
}

4. 重新编译工程, 运行

5. 注意观察启动后, 命令行里的字段, 类似于

2013/08/08 16:45:58 profile: cpu profiling enabled, /tmp/profile882806532/cpu.pprof
后面的路径就是pprof性能分析文件的位置, 启动机器人进行多次服务器测试用例, 停止机器人, Ctrl+C中断服务器
  6.将cpu.pprof拷贝到你的游戏exe所在位置
  7.下载并安装Graphviz, 这是将分析数据变成上图的图形化工具
  8.调用Graphviz制作文档
 go tool pprof --pdf gamesvc.exe cpu.pprof > report.pdf
如果dot没有找到, 可以在执行前添加路径
set path==%path%;"c:\Program Files (x86)\Graphviz2.38\bin"


上一篇:postgresql 异步流复制hot standby搭建
下一篇:Redis 启动警告错误解决

相关文章

相关评论

本站评论功能暂时取消,后续此功能例行通知。

一、不得利用本站危害国家安全、泄露国家秘密,不得侵犯国家社会集体的和公民的合法权益,不得利用本站制作、复制和传播不法有害信息!

二、互相尊重,对自己的言论和行为负责。

好贷网好贷款