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

news2024/11/20 3:32:03

最新版Golang pprof使用

🔥具体实践:

  • Go调试神器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://blog.csdn.net/weixin_45565886/article/details/137158092

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%:当前函数及当前函数调用其他函数分配总和占比

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1954945.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

python 查询机器python、gpu、安装包等环境版本信息

checkenv.py """Check environment configurations and dependency versions."""import importlib import os import resource import subprocess import sys from collections import OrderedDict, defaultdictimport torch# 查询自己想要的包…

【开源】一个基于 LLM 大语言模型的知识库问答系统,提供开箱即用的数据处理、模型调用等能力。

基于 LLM 大语言模型的知识库问答系统 基于大语言模型(Large Language Model,LLM)的知识库问答系统是一种利用先进的自然语言处理技术来理解用户查询并从知识库中检索出准确答案的系统。这里的LLM指的是能够处理和理解大量文本数据的人工智能…

【Go - 如何查看类型,运行前/运行时】

方式1 - 运行时查看 在Go中,你可以使用reflect.TypeOf()函数来获取变量的类型。这需要导入reflect包。以下是个示例,在运行时打印变量的类型: package mainimport ("context""fmt""reflect""go.mongodb…

精通推荐算法13:图神经网络之GraphSAGE

1 引言 近年来,图神经网络(Graph Neural Networks,GNN)在NLP、风控和推荐系统等领域的研究十分火热,其对推荐系统、生物医药、社交网络和知识图谱等非结构化数据有十分优秀的处理能力。基于图神经网络的Embedding表征…

用户登录安全是如何保证的?如何保证用户账号、密码安全?

1.HTTP协议直接传输密码(无加密) 前端 直接发送HTTP请求(无加密),攻击者可直接捕获网络包,看到下面的明文信息 因此,使用HTTP协议传输会直接暴露用户敏感信息。 2.HTTPS协议直接传输密码&…

windows环境 python + opencv 加载 onnx 人脸检测模型识别人脸测试

参考博客: 1. OpenCV-Python 4.5.4 人脸识别应用:https://blog.csdn.net/qq_36563273/article/details/121510440( 代码就是在此博客代码基础上改的,主要添加了人脸画框的逻辑 ) 1. windows环境:win11 2. 安装 miniconda2-4.7.1…

用python解释进程与协程(python实例二十八)

目录 1.认识Python 2.环境与工具 2.1 python环境 2.2 Visual Studio Code编译 3.创建进程池,异步执行多个任务 3.1 代码构思 3.2 代码示例 3.3 运行结果 4. 模拟协程堵塞 4.1 代码构思 4.2 代码示例 4.3 运行结果 5.总结 1.认识Python Python 是一个高…

算法019:x的平方根

x的平方根. - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。https://leetcode.cn/problems/sqrtx/ 这个题乍一看很奇怪,但是换个角度,我们用二分查找的思想来完成这个题。 …

组队学习——决策树(以泰坦尼克号公共数据集为例)

本次我们挑战的数据集为泰坦尼克号公共数据集,为了降低难度,我们在原有数据集的基础上进行了优化,具体数据集介绍如下: 在这里也介绍一下数据的含义吧 数据介绍: Survived:是否存活(label&#…

巧用外部资源加速任务执行

1. 背景 在人工智能时代,对算力的要求越来越高,为了加速任务的执行,可以削减软件层面的干扰以充分挖掘本机的硬件算力,具体可参考前面的文章。 若充分挖掘本机硬件能力之后还显不足,就需要增加硬件或提高硬件配置&am…

【小程序爬虫入门实战】使用Python爬取易题库

文章目录 1. 写在前面2. 抓包分析 【🏠作者主页】:吴秋霖 【💼作者介绍】:擅长爬虫与JS加密逆向分析!Python领域优质创作者、CSDN博客专家、阿里云博客专家、华为云享专家。一路走来长期坚守并致力于Python与爬虫领域研…

pinia定义store及其简单的使用

定义store 在使用pinia管理状态之前,我们得知道 Store 是用 defineStore() 定义的,它的第一个参数要求是一个独一无二的名字: import { defineStore } from "pinia";// 你可以任意命名 defineStore() 的返回值,但最好使用 store 的…

C语言 #指针数组 #数组指针 #数组参数、指针参数

文章目录 前言 一、指针数组 1、概念: 2、指针数组有什么用呢? 二、数组指针 1、数组指针的定义 2、数组名与 &数组名 的区别 3、数组指针如何初始化? 4、数组指针的用法 三、根据代码区分 指针数组 和 数组指针 四、数组参数、指针参数 …

【PYTHON】多进程运行示例含共享数据

运行结果 Python多进程调用示例 import multiprocessing import time import os import sys# 注册多个函数用于不同进程分别调用 def testcase0():time.sleep(1)return "case0_"+get_time()def testcase1(timestamp):return "case1_"+timestampdef testca…

使用Spring Boot与Spire.Doc实现Word文档的多样化操作

​ 博客主页: 南来_北往 系列专栏:Spring Boot实战 前言 使用Spring Boot与Spire.Doc实现Word文档的多样化操作具有以下优势: 强大的功能组合:Spring Boot提供了快速构建独立和生产级的Spring应用程序的能力,而Spire.Doc则…

CSS(三)——CSS 背景

CSS 背景 CSS 背景属性用于定义HTML元素的背景。 CSS 背景属性 Property描述background简写属性,作用是将背景属性设置在一个声明中。background-attachment背景图像是否固定或者随着页面的其余部分滚动。background-color设置元素的背景颜色。background-image把…

MySQL查询执行(二):order by工作原理

假设你要查询城市是“杭州”的所有人名字, 并且按照姓名排序返回前1000个人的姓名、 年龄。 假设这个表的部分定义是这样的: -- 创建表t CREATE TABLE t (id int(11) NOT NULL,city varchar(16) NOT NULL,name varchar(16) NOT NULL,age int(11) NOT N…

240728pycharm使用问题之无法找到指定命令

文章目录 1.问题描述2.分析3.解决后界面展示 1.问题描述 pycharm中断报错,让你初始化powershell,并且说找不到anconda中指定命令,很明显anaconda环境配置不对 2.分析 1.检查anaconda环境变量配置是否ok; 2.检查pycharm终端配置是否ok 3.检查pyacharm环境配置 3.解决后界面展…

第一期:AI芯片——智能时代的“芯”跳加速器

🌟 小竹笋的AI奇旅 🚀 Hey小伙伴们!👋 我是小竹笋,一名喜欢捣鼓技术、热爱创作的工程师。从今天开始,我们将踏上一场关于人工智能(AI)核心技术领域的探索之旅。第一站,我…

MarkTool之UDP

UDP客户端,主要作用是与UDP服务端连接进行数据通讯 1、连接参数有4个,绑定IP和Port,服务端IP和Port 2、接收数据和发送数据的参数设置,有16进制,有字符,有原始数据,都可进行选择 3、定时发送&a…