web项目中golang性能监控实例分析

发布时间:2022-04-14 15:18:03 作者:iii
来源:亿速云 阅读:192

这篇文章主要介绍“web项目中golang性能监控实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“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

查看电脑的配置:

scvg4: inuse: 111, idle: 54, sys: 187, released: 0, consumed: 198 (MB)

关于“web项目中golang性能监控实例分析”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注亿速云行业资讯频道,小编每天都会为大家更新不同的知识点。

推荐阅读:
  1. mongodb性能监控
  2. mongodb 性能监控

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

web golang

上一篇:C语言选择、循环、函数、数组与操作符实例分析

下一篇:C#怎么实现FTP上传文件

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》