web项目中golang性能监控解析
作者:Jeff的技术栈 发布时间:2024-02-18 17:28:23
性能监控
一、web项目(如gin中)
1.使用ginpprof
import "github.com/DeanThompson/ginpprof"
router := gin.Default()
ginpprof.Wrap(router)
2.使用pprof
只需要在main.go中引入:_ “net/http/pprof”
访问:127.0.0.1:8080/debug/pprof
/debug/pprof/profile:访问这个链接会自动进行 CPU profiling,持续 30s,并生成一个文件供下载
/debug/pprof/block:Goroutine阻塞事件的记录。默认每发生一次阻塞事件时取样一次。
/debug/pprof/goroutines:活跃Goroutine的信息的记录。仅在获取时取样一次。
/debug/pprof/heap: 堆内存分配情况的记录。默认每分配512K字节时取样一次。
/debug/pprof/mutex: 查看争用互斥锁的持有者。
/debug/pprof/threadcreate: 系统线程创建情况的记录。 仅在获取时取样一次。
二、单个的go文件如果查看gc
1.设置环境变量
set GODEBUG=gctrace=1
2.术语:
mark:标记阶段。
markTermination:标记结束阶段。
mutator assist:辅助 GC,是指在 GC 过程中 mutator 线程会并发运行,而 mutator assist 机制会协助 GC 做一部分的工作。
heaplive:在 Go 的内存管理中,span 是内存页的基本单元,每页大小为 8kb,同时 Go 会根据对象的大小不同而分配不同页数的 span,而 heaplive 就代表着所有 span 的总大小。
dedicated / fractional / idle:在标记阶段会分为三种不同的 mark worker 模式,分别是 dedicated、fractional 和 idle,它们代表着不同的专注程度,其中 dedicated 模式最专注,是完整的 GC 回收行为,fractional 只会干部分的 GC 行为,idle 最轻松
P:指处理器
3.含义
gc 4 @0.254s 5%: 2.0+1.0+9.9 ms clock, 16+0/2.0/2.0+79 ms cpu, 4->4->0 MB, 5 MB goal, 8 P
gc 4 :GC 执行次数的编号,每次叠加。第4次 GC。
@0.254s:自程序启动后到当前的具体秒数。:当前是程序启动后的 0.254s。
5%:自程序启动以来在GC中花费的时间百分比。程序启动后到现在共花费 5% 的时间在 GC 上
2.0+1.0+9.9ms clock:GC 的标记工作共使用的 CPU 时间占总 CPU 时间的百分比。
2.0表示单个 P 在 mark 阶段的 STW 时间。(stop the world)
1.0表示所有 P 的 mark concurrent(并发标记)所使用的时间。
9.9表示单个 P 的 markTermination 阶段的 STW 时间
16+0/2.0/2.0+79 ms cpu
16:表示整个进程在 mark 阶段 STW 停顿的时间。
0/2.0/2.0:0表示 mutator assist 占用的时间,2.0表示 dedicated + fractional 占用的时间,2.0 表示 idle 占用的时间。
4->4->0 MB
4表示开始 mark 阶段前的 heap_live 大小。
4表示开始 markTermination 阶段前的 heap_live 大小。
1表示被标记对象的大小。
5 MB goal:表示下一次触发 GC 回收的阈值是 5 MB。
8 P:本次 GC 一共涉及多少个 P
查看电脑的配置:
运行-- dxdiag
设备管理器
scvg4: inuse: 111, idle: 54, sys: 187, released: 0, consumed: 198 (MB)
inuse: 111,:使用多少M内存
idle: 54,:0 剩下要清除的内存
sys: 187,: 系统映射的内存
released: 0,: 释放的系统内存
consumed: 198: 申请的系统内存
来源:https://www.cnblogs.com/guyouyin123/p/15148750.html
猜你喜欢
- 使用xlwt读取txt文件内容,并且写入到excel中,代码如下,已经加了注释。代码简单,具体代码如下:# coding=utf-8'
- array和asarray都可以将结构数据转化为ndarray,但是主要区别就是当数据源是ndarray时,array仍然会copy出一个副
- 一、包在我们的项目中,可能会有太多的模块但是我们不能把所有的模块这样放在这里,这样项目会乱七八糟。我们可以将所有相同类型的模块放在一个文件夹
- 在爬虫百度地图的期间,就为它做了一个界面,运用的是PyQt5。得到意想不到的结果:# -*- coding: utf-8 -*-# Form
- int(10)int(20)分别代表什么意思储备知识在设计数据库表的时候,经常需要设计一个id字段,它的类型一般都是整型int,经常会遇到i
- 通常来说Python中任何值都是一个对象,因此任何类型(int、str、list…)都是一个类。而类就必然有它的方法或属性,我们要记下这么多
- Hello every, 我是Sunrise_Chen,有人知道我吗?好久没来这里了,以前偶尔会来这里潜水今天心情很好,写了几个特效果。特效
- 本文实例讲述了Python使用cx_Freeze库生成msi格式安装文件的方法。分享给大家供大家参考,具体如下:①.需要在目录下面创建一个文
- 今天在pycharm(我用的python3)练习的时候,发现报了个AttributeError: module 'urllib
- The Only Thing We Have To Fear Is Premature Standardization原文地址:http:/
- 连接:mysql -h主机地址 -u用户名 -p用户密码 (注:u与root可以不用加空格,其它也一样)断开:exit (回车)创建授权:g
- key: [com.alibaba.druid.stat.DruidDataSourceStatManager.addDataSource(
- 有时候,规划师(或需求、交互)把内容呈现的框架草图搭建好后,就直接“丢”给了设计师,让设计师在画好的框架里去美化内容,出来后的效果,往往达不
- 第一个版本在这个版本中,首先创建了 RouterConfig 对象,其构造方法创建了 tornado.web.Application() 并
- 导读需要使用python做一个将很多个不规则PPT导出成用文件夹归纳好的图片集,所以就需要使用comtypes调用本机电脑上的ppt软件,批
- Python TutorPython Tutor 是由 Philip Guo 开发的一个免费教育工具,可帮助学生攻克编程学习中的基础障碍,理
- 一、网络结构的可视化我们训练神经网络时,除了随着step或者epoch观察损失函数的走势,从而建立对目前网络优化的基本认知外,也可以通过一些
- 看到Django和layim实现websocketde资料很少,自己就琢磨了下,顺便搭建出来了。自己要去找闲心大神授权呀。先来看图这是初次搭
- 问题:“深入认识Python内建类型”这部分的内容会从源码角度为大家介绍Python中各种常用的内建
- 一、统计语句1、--统计当前【>当天00点以后的数据】SELECT * FROM 表 WHERE CONVERT(Nvarchar,