【Go知识专栏】pprof

pprof是Go语言中的一个性能分析工具,用于查找和分析程序错误,如内存泄漏、race冲突和协程泄漏。通过监听端口或使用库生成文件进行分析,常见使用场景包括内存使用、协程堆栈和CPU使用情况。pprof提供了多种分析命令,如top、list和web,帮助开发者深入理解程序性能瓶颈。底层原理涉及堆内存、协程栈和CPU样本的收集,确保有效而准确的分析结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简说 pprof

pprof 是一个可视化和分析数据的工具。该工具可读取分析样本并生成可视化报告,从而帮助程序分析。

1. 使用场景

  • 查找分析程序中的错误,如内存泄漏,race 冲突,协程泄漏
  • 程序优化,分析程序性能瓶颈

2. 如何使用

  • 方式一:

使用 net/http/pprof 监听相应的端口,并通过浏览器打开查看

package main
import (
  "fmt"
  "net/http"
  _ "net/http/pprof"
)

func main(){
   
   
  http.HandleFunc("/",)
  if err := http.ListenAndServe(":7080",nil);err != nil {
   
   
    fmt.Printf("http.ListenAndServe failed, err:%+v",err)
  }
}

查看内存使用情况:

http://localhost:7080/debug/pprof/heap

查看协程堆栈信息:

http://localhost:7080/debug/pprof/goroutine

查看 30s 内 CPU 使用情况:

http://localhost:7080/debug/pprof/profile?seconds=30

  • 方式二:

使用 runtime/pprof 库,在适当的位置调用并最终生成文件

package main
import(
	"os"
	"fmt"
	"runtime/pprof"
)
func main() {
   
   
	// 记录 CPU 使用
	cpuf,err := os.Create("./cpuprofile")
	if err != nil {
   
   
		fmt.Printf("create cpu profile failed, err: %+v", err)
		return
	}
	defer cpuf.Close()
	pprof.StartCPUProfile(cpuf)
	defer pprof.StopCPUProfile()
  // 记录堆内存使用
	memf
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值