为golang程序使用pprof远程查看httpserver运行堆栈,cpu耗时等信息

pprof是个神马玩意儿?

pprof - manual page for pprof (part of gperftools)

是gperftools工具的一部分

gperftools又是啥?

These tools are for use by developers so that they can create more robust applications. Especially of use to those developing multi-threaded applications in C++ with templates. Includes TCMalloc,heap-checker,heap-profiler and cpu-profiler.

一个性能分析的工具,可以查看堆栈、cpu信息等等。

在golang中如何使用呢?下面就来看看。

1. 在一个httpserver中,只需要一行代码

package main

import (
"flag"
"log"
"net/http"
_ "net/http/pprof"
"sync"
"time"
)


func main() {
flag.Parse()

//这里实现了远程获取pprof数据的接口
go func() { log.Println(http.ListenAndServe("localhost:6060",nil)) }()

var wg sync.WaitGroup
wg.Add(10)
for i := 0; i < 10; i++ {
go work(&wg)
}

wg.Wait()
// Wait to see the global run queue deplete.
time.Sleep(3 * time.Second)
}

func work(wg *sync.WaitGroup) {
time.Sleep(time.Second)

var counter int
for i := 0; i < 1e10; i++ {
time.Sleep(time.Millisecond * 100)
counter++
}
wg.Done()
}

2.编译运行这个程序

go buildtrace_example.go

./trace_example

3. 通过浏览器访问

http://localhost:6060/debug/pprof/

能够查看到程序的overview

4.你也可以通过终端命令查看

Then use the pprof tool to look at the heap profile:

go tool pprof http://localhost:6060/debug/pprof/heap

Or to look at a 30-second CPU profile:

go tool pprof http://localhost:6060/debug/pprof/profile

Or to look at the goroutine blocking profile:

go tool pprof http://localhost:6060/debug/pprof/block



qpzhang@qpzhangdeMac-mini:~/gocode $go tool pprof http://localhost:6060/debug/pprof/profile
Read http://localhost:6060/debug/pprof/symbol
Gathering CPU profile from http://localhost:6060/debug/pprof/profile?seconds=30 for 30 seconds to
  /var/folders/2l/195zcc1n0sn2wjfjwf9hl9d80000gn/T/mmBnpdkv0D
Be patient...
Wrote profile to /var/folders/2l/195zcc1n0sn2wjfjwf9hl9d80000gn/T/mmBnpdkv0D
Welcome to pprof!  For help,type 'help'.
(pprof) top10
Total: 9 samples
       6  66.7%  66.7%        6  66.7% runtime.mach_semaphore_wait
       1  11.1%  77.8%        1  11.1% runtime.kevent
       1  11.1%  88.9%        1  11.1% runtime.mach_semaphore_signal
       1  11.1% 100.0%        1  11.1% runtime.mach_semaphore_timedwait
       0   0.0% 100.0%        7  77.8% System
       0   0.0% 100.0%        1  11.1% notetsleep
       0   0.0% 100.0%        1  11.1% ready
       0   0.0% 100.0%        2  22.2% runtime.gosched0
       0   0.0% 100.0%        1  11.1% runtime.mach_semrelease
       0   0.0% 100.0%        1  11.1% runtime.notetsleepg
(pprof) web
Total: 9 samples
Loading web page file:////var/folders/2l/195zcc1n0sn2wjfjwf9hl9d80000gn/T/SlFUZhzBDB.0.svg

web命令生成了很cool的svg图片,在浏览器中打开。







除了远程拉取,你还可以自己编写代码,把这些数据写入文件(实现 net/http/pprof 中的几个路由,开启或关闭追踪信息)。
具体可参考:http://blog.golang.org/profiling-go-programs
https://github.com/hyper-carrot/go_command_tutorial/blob/master/0.12.md

期间:web命令依赖一个svg生成包,在mac下面,你可以通过http://www.graphviz.org/Download_macos.php进行下载。


转自:http://www.cnblogs.com/zhangqingping/p/4345071.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


类型转换 1、int转string 2、string转int 3、string转float 4、用户结构类型转换
package main import s &quot;strings&quot; import &quot;fmt&quot; var p = fmt.Println func main() { p(&quot;Contains: &quot;, s.Contains(&quot;test&quo
类使用:实现一个people中有一个sayhi的方法调用功能,代码如下: 接口使用:实现上面功能,代码如下:
html代码: beego代码:
1、读取文件信息: 2、读取文件夹下的所有文件: 3、写入文件信息 4、删除文件,成功返回true,失败返回false
配置环境:Windows7+推荐IDE:LiteIDEGO下载地址:http://www.golangtc.com/downloadBeego开发文档地址:http://beego.me/docs/intro/ 安装步骤: 一、GO环境安装 二、配置系统变量 三、Beego安装 一、GO环境安装 根
golang获取程序运行路径:
Golang的文档和社区资源:为什么它可以帮助开发人员快速上手?
Golang:AI 开发者的实用工具
Golang的标准库:为什么它可以大幅度提高开发效率?
Golang的部署和运维:如何将应用程序部署到生产环境中?
高性能AI开发:Golang的优势所在
本篇文章和大家了解一下go语言开发优雅得关闭协程的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。1.简介本文将介绍首先为什么需要主...
这篇文章主要介绍了Go关闭goroutine协程的方法,具有一定借鉴价值,需要的朋友可以参考下。下面就和我一起来看看吧。1.简介本文将介绍首先为什么需要主动关闭gor...
本篇文章和大家了解一下go关闭GracefulShutdown服务的几种方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。目录Shutdown方法Regi...
这篇文章主要介绍了Go语言如何实现LRU算法的核心思想和实现过程,具有一定借鉴价值,需要的朋友可以参考下。下面就和我一起来看看吧。GO实现Redis的LRU例子常
今天小编给大家分享的是Go简单实现多租户数据库隔离的方法,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会...
这篇“Linux系统中怎么安装NSQ的Go语言客户端”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希
本文小编为大家详细介绍“怎么在Go语言中实现锁机制”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么在Go语言中实现锁机制”文章能帮助大家解决疑惑,下面...
今天小编给大家分享一下Go语言中interface类型怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考