web项目中golang性能监控实例分析(golang,web,开发技术)

时间:2024-05-02 04:33:25 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

    web%E9%A1%B9%E7%9B%AE%E4%B8%ADgolang%E6%80%A7%E8%83%BD%E7%9B%91%E6%8E%A7%E5%AE%9E%E4%BE%8B%E5%88%86%E6%9E%90

1.使用ginpprof

2.使用pprof

只需要在main.go中引入:_ “net/http/pprof”

访问:127.0.0.1:8080/debug/pprof

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: 申请的系统内存

本文:web项目中golang性能监控实例分析的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:C语言选择、循环、函数、数组与操作符实例分析下一篇:

12 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18