web项目中golang性能监控解析

 更新时间:2022年04月14日 12:51:05   作者:Jeff的技术栈  
这篇文章主要为大家介绍了web项目中golang性能监控详细的解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪

性能监控

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

以上就是web项目中golang性能监控解析的详细内容,更多关于web中golang性能监控的资料请关注脚本之家其它相关文章!

相关文章

  • Golang全局变量加锁的问题解决

    Golang全局变量加锁的问题解决

    这篇文章主要介绍了解决Golang全局变量加锁的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-05-05
  • GO使用阿里云,解决go get下载项目慢或无法下载的情况

    GO使用阿里云,解决go get下载项目慢或无法下载的情况

    这篇文章主要介绍了GO使用阿里云,解决go get下载项目慢或无法下载的情况,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • 一文弄懂用Go实现MCP服务的示例代码

    一文弄懂用Go实现MCP服务的示例代码

    本文主要介绍了一文弄懂用Go实现MCP服务的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-04-04
  • Go语言实现一个Http Server框架(二) Server的抽象

    Go语言实现一个Http Server框架(二) Server的抽象

    上一篇文章对http库的基本使用做了说明,这篇文章主要介绍了如何实现一个简单地httpServer,文中代码示例非常详细,感兴趣的朋友可以参考下
    2023-04-04
  • golang避免内存溢出的方法

    golang避免内存溢出的方法

    内存溢出(Memory Overflow)是指程序在运行时超出了分配给它的内存限制,从而导致程序异常或崩溃的现象,内存溢出的问题在任何编程语言中都可能出现,Go 语言也不例外,本文给大家介绍了golang是如何解决内存溢出的,需要的朋友可以参考下
    2024-09-09
  • GoLang string与strings.Builder使用对比详解

    GoLang string与strings.Builder使用对比详解

    这篇文章主要介绍了GoLang string与strings.Builder使用对比,Builder 用于使用 Write 方法有效地构建字符串。它最大限度地减少了内存复制。零值可以使用了。不要复制非零生成器
    2023-03-03
  • golang 实现tcp server端和client端,并计算RTT时间操作

    golang 实现tcp server端和client端,并计算RTT时间操作

    这篇文章主要介绍了golang 实现tcp server端和client端,并计算RTT时间操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • grpool goroutine池协程管理

    grpool goroutine池协程管理

    这篇文章主要介绍了grpool goroutine池协程管理,goroutine协程非常轻量级,这也是为什么go支持高并发,但是goroutine频繁创建销毁对GC的压力比较大,文章围绕主题展开详细的内容介绍,需要的小伙伴可以参考一下
    2022-06-06
  • go 熔断原理分析与源码解读

    go 熔断原理分析与源码解读

    这篇文章主要为大家介绍了go 熔断原理分析与源码解读,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • golang调试bug及性能监控方式实践总结

    golang调试bug及性能监控方式实践总结

    这篇文章主要为大家介绍了golang调试bug及性能监控方式实践是总结,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05

最新评论