最新版Golang pprof使用详解(引入、抓取、分析,图文结合)

 更新时间:2024年08月01日 10:53:26   作者:NPE~  
这篇文章主要介绍了最新版Golang pprof使用详解包括引入、抓取、分析,图文结合,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

最新版Golang pprof使用

🔥具体实践:

Github地址:https://github.com/ziyifast/ziyifast-code_instruction/tree/main/go-demo/go-pprof

引入pprof:import _ “net/http/pprof”

引入pprof包,监听某个端口即可

一旦服务器启动,pprof 就开始收集关于程序的性能数据,包括 CPU 使用情况、内存使用情况、阻塞事件、锁竞争、goroutine 和线程统计信息等。当客户端请求 pprof 的路由时,pprof 会根据请求的类型提供相应的数据

package main
import "net/http"
import _ "net/http/pprof"
func main() {
	http.ListenAndServe(":8080", nil)
	select {}
}

文字版pprof信息:

http://ip:port/debug/pprof

引入包之后,启动服务,浏览器访问http://ip:port/debug/pprof,即可查看文字版pprof信息。

比如我本地监控8080,我浏览器访问http://localhost:8080/debug/pprof:

图形化查看:go tool pprof -http=“0.0.0.0:8089”

http://127.0.0.1:8080/debug/pprof/goroutine

如果觉得文字版不直观,我们也可以本地再通过pprof工具启一个web端口,以图形化方式观察:

//监听远程pprof信息,并将其转换为图形化
//我这里拿本地127.0.0.1做演示。监听远程pprof,将127.0.0.1更换为对应ip即可
go tool pprof -http="0.0.0.0:8089"  http://127.0.0.1:8080/debug/pprof/goroutine

下载pprof信息到文件:curl -o heap.out http://IP:Port/debug/pprof/heap

//采样pprof信息到文件,以采集heap信息为例:
//curl -o heap.out http://IP:Port/debug/pprof/heap
curl -o heap.out http://localhost:8080/debug/pprof/heap

下载pprof heap信息为heap.out文件:

直接抓取pprof信息并分析:

go tool pprof -seconds=5 http://localhost:8080/debug/pprof/profile

//采样pprof信息并进入pprof命令行
go tool pprof -seconds=5 http://localhost:8080/debug/pprof/profile

采集cpu信息并分析:

本地加载pprof文件:go tool pprof heap.out

//go tool pprof 文件名
go tool pprof heap.out

保存pprof为图片:png、svg

//命令行进入pprof
go tool pprof heap.out
//导出png图片(导出svg,输入svg即可)
png

top查看占用情况、list查看详情

以获取内存为例:

  • flat:当前函数分配的内存,不包含它调用其他函数造成的内存分配
  • flat%:当前函数分配内存占比
  • sum%:自己和前面所有的flat%累积值
  • cum:当前函数及当前函数调用其他函数的分配内存的汇总
  • cum%:这个函数分配的内存,以及它调用其他函数分配的内存之和
//命令行进入pprof
go tool pprof heap.out
//top 5,查看占用前5的函数
top 5
//list + 函数名,查看函数详情(具体是哪个位置占用较高)
list http.HandlerFunc.ServeHTTP

参数解析

详情请见:https://www.jb51.net/jiaoben/319016j3j.htm

allocs:内存分配,历史累计

allocs: A sampling of all past memory allocations【所有内存分配,历史累计】

block:导致阻塞的堆栈记录,历史累计

block: Stack traces that led to blocking on synchronization primitives【导致阻塞同步的堆栈,历史累计】

cmdline:当前程序命令行完整调用路径

cmdline: The command line invocation of the current program【当前程序命令行的完整调用路径】

goroutine:当前程序所有goroutine堆栈信息,实时变化

goroutine: Stack traces of all current goroutines. Use debug=2 as a query parameter to export in the same format as an unrecovered panic.【当前所有运行的goroutine堆栈信息,实时变化】

heap:活动对象内存分配情况,实时变化

heap: A sampling of memory allocations of live objects. You can specify the gc GET parameter to run GC before taking the heap sample.【查看活动对象的内存分配情况,实时变化】

mutex:锁竞争记录,历史累计

mutex: Stack traces of holders of contended mutexes【导致互斥锁竞争持有者的堆栈跟踪,历史累计】

profile:cpu使用情况

profile: CPU profile. You can specify the duration in the seconds GET parameter. After you get the profile file, use the go tool pprof command to investigate the profile.【默认进行30s的CPU Profing,用于观察CPU使用情况】

threadcreate:新线程创建情况

threadcreate: Stack traces that led to the creation of new OS threads【查看创建新OS线程的堆栈跟踪信息】

trace:当前程序执行链路

trace: A trace of execution of the current program. You can specify the duration in the seconds GET parameter. After you get the trace file, use the go tool trace command to investigate the trace.【当前程序执行链路】

其他参数 flat:当前函数的数据,不含调用其他函数

以内存为例, flat:当前函数分配的内存,不包含它调用其他函数造成的内存分配

flat%:当前函数分配占比

例:flat%:当前函数分配内存占比

sum%:自己和前面所有的flat%累积值 cum:当前函数及当前函数调用其他函数分配总和

例: 当前函数及当前函数调用其他函数的分配内存的汇总

cum%:当前函数及当前函数调用其他函数分配总和占比

例:这个函数分配的内存,以及它调用其他函数分配的内存之和

到此这篇关于最新版Golang pprof使用(引入、抓取、分析,图文结合)的文章就介绍到这了,更多相关Golang pprof使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Go语言使用时会遇到的错误及解决方法详解

    Go语言使用时会遇到的错误及解决方法详解

    这篇文章主要为大家详细介绍了Go语言使用时常常会遇到的一些错误及解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2023-07-07
  • golang waitgroup辅助并发控制使用场景和方法解析

    golang waitgroup辅助并发控制使用场景和方法解析

    Golang 提供了简洁的 go 关键字来让开发者更容易的进行并发编程,同时也提供了 WaitGroup 对象来辅助并发控制,今天我们就来分析下 WaitGroup 的使用方法,顺便瞧一瞧它的底层源码
    2023-09-09
  • Go语言中使用gorm小结

    Go语言中使用gorm小结

    这篇文章主要给大家介绍了Go语言中如何使用gorm,文中介绍的很详细,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-12-12
  • gorm+gin实现restful分页接口的实践

    gorm+gin实现restful分页接口的实践

    本文主要介绍了gorm+gin实现restful分页接口的实践,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • Golang极简入门教程(四):编写第一个项目

    Golang极简入门教程(四):编写第一个项目

    这篇文章主要介绍了Golang极简入门教程(四):编写第一个项目,本文讲解了workspace、包路径、第一个可执行命令等内容,需要的朋友可以参考下
    2014-10-10
  • Golang gRPC HTTP协议转换示例

    Golang gRPC HTTP协议转换示例

    这篇文章主要为大家介绍了Golang gRPC HTTP协议转换示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • Go 语言入门学习之正则表达式

    Go 语言入门学习之正则表达式

    这篇文章主要介绍了Go 语言入门学习之正则表达式,文章基于GO语言的相关资料展开详细内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-04-04
  • Golang实现IO操作

    Golang实现IO操作

    本文主要介绍了Golang实现IO操作,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-05-05
  • 深入浅出Golang中的sync.Pool

    深入浅出Golang中的sync.Pool

    sync.Pool是可伸缩的,也是并发安全的,其大小仅受限于内存大小。本文主要为大家介绍一下Golang中sync.Pool的原理与使用,感兴趣的小伙伴可以了解一下
    2023-03-03
  • Go语言中的并发模式你了解了吗

    Go语言中的并发模式你了解了吗

    工作中查看项目代码,发现会存在使用 GO 语言做并发的时候出现各种各样的异常情况,实际上,出现上述的情况,还是因为我们对于 GO 语言的并发模型和涉及的 GO 语言基础不够扎实,所以本文小编就来带大家深入了解下Go语言中的并发模式吧
    2023-08-08

最新评论