golang cpu性能图形分析工具

本文记录了如何使用Golang进行CPU性能分析,包括编写测试代码、生成及解析`.prof`文件,以及可选地利用组件创建火焰图,帮助直观定位性能问题。
摘要由CSDN通过智能技术生成

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
生
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值