go-runtime/pprof

软件包 pprof主要功能是可视化工具所期望的格式写入运行时的分析数据

  • 获取所有已知profile的切片,按名称排序
  • 开启/关闭 当前进程CPU profile
  • 如何将当前进程的堆栈信息写入文件中
  • 新建profile
  • 将当前栈添加到分析中
  • 获取当前执行栈的数量
  • 从该分析中移除与值value相关联的执行栈
  • 将profile写入到文件中
  • 通过名称查找profile

开始之前先下载性能文件分析工具,下载地址: http://www.graphviz.org/download/

获取所有已知profile的切片,按名称排序

func Profiles() []*Profile

type Profile struct {
    // 内含隐藏或非导出字段
}

Profile是一个调用栈踪迹的集合,显示导致特定事件(如内存分配)的实例的调用栈序列。包可以创建并维护它们自己的profile;它一般用于跟踪必须被显式关闭的资源,例如文件或网络连接
一个Profile的方法可被多个Go程同时调用

package main

import (
    "runtime/pprof"
    "fmt"
)

func main() {
 profiles :=  pprof.Profiles()
 for _,profile := range profiles{
     fmt.Println(profile.Name())
     fmt.Println(profile.Count())
 }
}

image.png

通过pprof.Profiles 我们获取到了main方法的堆栈信息

goroutine - 当前Go所有程的调用栈踪迹
heap - 所有堆分配的采样
threadcreate - 导致新的OS线程创建的调用栈踪迹
block - 导致同步原语水平的阻塞的调用栈踪迹`

开启cpu profile

func StartCPUProfile(w io.Writer) error
func StopCPUProfile()

package main

import (
  "os"
  "runtime/pprof"
  "time"
  )

func main() {
  // 程序结束时关闭  
  defer pprof.StopCPUProfile()
  // 开启cpu性能检测
  file,_:= os.Create("/Users/xujie/go/src/awesomeProject/main/profile.pprof")
  pprof.StartCPUProfile(file)
  time.Sleep(time.Second)
}

如何将当前堆栈信息写入文件中去

package main

import (
    "os"
    "runtime/pprof"
    "fmt"
)

func main() {

 file,_:= os.Open("/Users/xujie/go/src/awesomeProject/main/profile.pprof")
 error := pprof.WriteHeapProfile(file)
 if error != nil{
     fmt.Println(error)
 }
}

通过上面代码我们已经将当前进程的数据写入文件中了,接下来我们使用命令查看一下

go tool pprof /Users/xujie/go/src/awesomeProject/main/profile.pprof

image.png

新建profile

func (p *Profile) Add(value interface{}, skip int)

将当前栈添加到分析中

func (p *Profile) Add(value interface{}, skip int)
Add 将当前的执行栈添加到该分析中,并与value关联。Add在一个内部映射中存储值,因此value必须适于用作映射键,且在对应的Remove调用之前不会被垃圾收集。

若分析的映射中已经存在value键,Add就会引发panic。

获取当前执行栈的数量

func (p *Profile) Count() int
Count返回该Profile中当前执行栈的数量。

从该分析中移除与值value相关联的执行栈

func (p *Profile) Remove(value interface{})
Remove从该分析中移除与值value相关联的执行栈。若值value不在此分析中,则不做操作。

将profile写入到文件中

func (p *Profile) WriteTo(w io.Writer, debug int) error
函数将pprof格式的profile快照写入w中。若一个向w的写入返回一个错误,WriteTo就会返回该错误;否则会返回nil。

debug 参数用于开启附加的输出。如果debug=0,只会打印pprof所需要的十六进制地址;如果debug=1,会将地址翻译为函数名和行号并添加注释,以便让程序员无需工具阅读分析报告。
预定义Profile为其它debug值赋予了含义。例如,当打印“Go程”的分析报告时,debug=2意为:由于不可恢复的恐慌而濒临崩溃时,使用与Go程序相同的格式打印Go程的堆栈信息。

通过名字查找profile

func Lookup(name string) *Profile

下面我们演示一下


import (
    "runtime/pprof"
    "os"
    "fmt"
)
func main() {
 file,_ := os.Create("/Users/xujie/go/src/awesomeProject/main/profile.pro")
 profile := pprof.NewProfile("main") // 1.新建
 profile.Add("analyse",1) //2
 error := profile.WriteTo(file,1) // debug=1,会将地址翻译为函数名和行号并添加注释
 fmt.Println(error)
}

profile.pro 文件内容

image.png

软件包 pprof主要功能是可视化工具所期望的格式写入运行时的分析数据

  • 获取所有已知profile的切片,按名称排序
  • 开启/关闭 当前进程CPU profile
  • 如何将当前进程的堆栈信息写入文件中
  • 新建profile
  • 将当前栈添加到分析中
  • 获取当前执行栈的数量
  • 从该分析中移除与值value相关联的执行栈
  • 将profile写入到文件中
  • 通过名称查找profile

开始之前先下载性能文件分析工具,下载地址: http://www.graphviz.org/download/

获取所有已知profile的切片,按名称排序

func Profiles() []*Profile

type Profile struct {
    // 内含隐藏或非导出字段
}

Profile是一个调用栈踪迹的集合,显示导致特定事件(如内存分配)的实例的调用栈序列。包可以创建并维护它们自己的profile;它一般用于跟踪必须被显式关闭的资源,例如文件或网络连接
一个Profile的方法可被多个Go程同时调用

package main

import (
    "runtime/pprof"
    "fmt"
)

func main() {
 profiles :=  pprof.Profiles()
 for _,profile := range profiles{
     fmt.Println(profile.Name())
     fmt.Println(profile.Count())
 }
}

image.png

通过pprof.Profiles 我们获取到了main方法的堆栈信息

goroutine - 当前Go所有程的调用栈踪迹
heap - 所有堆分配的采样
threadcreate - 导致新的OS线程创建的调用栈踪迹
block - 导致同步原语水平的阻塞的调用栈踪迹`

开启cpu profile

func StartCPUProfile(w io.Writer) error
func StopCPUProfile()

package main

import (
  "os"
  "runtime/pprof"
  "time"
  )

func main() {
  // 程序结束时关闭  
  defer pprof.StopCPUProfile()
  // 开启cpu性能检测
  file,_:= os.Create("/Users/xujie/go/src/awesomeProject/main/profile.pprof")
  pprof.StartCPUProfile(file)
  time.Sleep(time.Second)
}

如何将当前堆栈信息写入文件中去

package main

import (
    "os"
    "runtime/pprof"
    "fmt"
)

func main() {

 file,_:= os.Open("/Users/xujie/go/src/awesomeProject/main/profile.pprof")
 error := pprof.WriteHeapProfile(file)
 if error != nil{
     fmt.Println(error)
 }
}

通过上面代码我们已经将当前进程的数据写入文件中了,接下来我们使用命令查看一下

go tool pprof /Users/xujie/go/src/awesomeProject/main/profile.pprof

image.png

新建profile

func (p *Profile) Add(value interface{}, skip int)

将当前栈添加到分析中

func (p *Profile) Add(value interface{}, skip int)
Add 将当前的执行栈添加到该分析中,并与value关联。Add在一个内部映射中存储值,因此value必须适于用作映射键,且在对应的Remove调用之前不会被垃圾收集。

若分析的映射中已经存在value键,Add就会引发panic。

获取当前执行栈的数量

func (p *Profile) Count() int
Count返回该Profile中当前执行栈的数量。

从该分析中移除与值value相关联的执行栈

func (p *Profile) Remove(value interface{})
Remove从该分析中移除与值value相关联的执行栈。若值value不在此分析中,则不做操作。

将profile写入到文件中

func (p *Profile) WriteTo(w io.Writer, debug int) error
函数将pprof格式的profile快照写入w中。若一个向w的写入返回一个错误,WriteTo就会返回该错误;否则会返回nil。

debug 参数用于开启附加的输出。如果debug=0,只会打印pprof所需要的十六进制地址;如果debug=1,会将地址翻译为函数名和行号并添加注释,以便让程序员无需工具阅读分析报告。
预定义Profile为其它debug值赋予了含义。例如,当打印“Go程”的分析报告时,debug=2意为:由于不可恢复的恐慌而濒临崩溃时,使用与Go程序相同的格式打印Go程的堆栈信息。

通过名字查找profile

func Lookup(name string) *Profile

下面我们演示一下


import (
    "runtime/pprof"
    "os"
    "fmt"
)
func main() {
 file,_ := os.Create("/Users/xujie/go/src/awesomeProject/main/profile.pro")
 profile := pprof.NewProfile("main") // 1.新建
 profile.Add("analyse",1) //2
 error := profile.WriteTo(file,1) // debug=1,会将地址翻译为函数名和行号并添加注释
 fmt.Println(error)
}

profile.pro 文件内容

image.png
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,165评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,503评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,295评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,589评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,439评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,342评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,749评论 3 387
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,397评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,700评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,740评论 2 313
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,523评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,364评论 3 314
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,755评论 3 300
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,024评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,297评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,721评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,918评论 2 336

推荐阅读更多精彩内容

  • 【编者按】应书中相关人物的要求,决定将之前的长篇连载小说《二赵的故事》更名为《沮水清清》。因此而给大家带来的不便在...
    静听旁白阅读 258评论 0 3
  • 1、完成6月份的发票、凭证的装订工作。 2、7份税单已全部交付银行,并扣款成功 3、申宝7月份共收付款303笔,继...
    dhy粒米阅读 98评论 0 0