0 背景
图形可以帮助我们直观的查看并定位问题,而cpu使用情况是一个比较重要的衡量指标。golang是属于一门注重性能的语言,自带了runtime/pprof
来分析,这里做下简单记录。
1 开始之前
1.1 测试代码
package main
import (
"flag"
"fmt"
"os"
"runtime/pprof"
)
var cpuprofile = flag.String("cpuprofile", "", "write cpu profile to file")
func main() {
flag.Parse()
if *cpuprofile == "" {
fmt.Println("null")
}
f, err := os.Create(*cpuprofile)
if err != nil {
fmt.Printf("error, err:%v", err)
}
pprof.StartCPUProfile(f)
defer pprof.StopCPUProfile()
val1 := 1
val2 := "hello"
for i := 0; i < 100000000; i++ {
//fmt.Sprintf("%v_%v", val1, val2)
fmt.Sprintf("%d_%s", val1, val2)
}
}
1.2 安装火焰图生成组件(可选)
go get github.com/uber/go-torch
生