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


猜你喜欢
- 一、数组和切片的区别是什么?1.数组数组是内置(build-in)类型,是一组同类型数据的集合,它是值类型,通过从0开始的下标索引访问元素值
- 在开发过程中,我们有时会遇到这样的问题,将 2020-11-08T08:18:46+08:00 转成 2020-11-08 08:18:46
- 这篇文章主要介绍了Python timer定时器两种常用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值
- 第一种方法(推荐)适用于随机取一个值, 返回一个值import randomlist1 = ['佛山', '南宁
- 前言我们百度搜索一些东西得时候,经常找到文档里面然后就会发现需要充值才能复制!怎么可以不花钱也保存呢?今天就分享给大家一个python获取文
- 字符串字符串常用操作拼接字符串拼接字符串需要使用‘+’运算符可完成对多个字符串的拼接。如str =
- Nodemailer是一个简单易用的Node.js邮件发送组件,具体操作如下1、安装nodemailernpm install nodema
- 语法糖(Syntactic sugar),也译为糖衣语法,是由英国计算机科学家彼得·约翰·兰达(Peter J. Landin)发明的一个术
- 编码规范Python 编码规范重要性的原因用一句话来概括就是:统一的编码规范可以提高开发效率。无论你是 编程者,还是 阅读者,好的规范能让你
- 代码如下import sysfrom PyQt5.QtWidgets import QApplication, QWidgetclass E
- 前言最近遇到一个统计查询需求,要求一次性查询多个统计信息,其中两个查询信息不在一个表中,也没有业务关联,表中也没有做连接处理。不考虑产品设计
- 用了on error resume next则在这句往后的代码就算出错也会继续执行具体有没有错可以用err.number来判断err.num
- 一、我们对XML的读取进行一波演示import xml.dom.minidom#负责解析xml文件的包from xml.dom.minido
- JavaScript 有三种弹窗 Alert (只有确定按钮), Confirmation (确定,取消等按钮), Prompt (有输入对
- 两种方式:1.IP+SID方式 2.配置链接方式1..IP+SID方式DbHelperOracle.connectionString = s
- 如何远程读取数据库页面?见下:<%Set HttpObj = Server.CreateObject(&
- 相信大家使用MySQL都有过重装的经历,要是重装MySQL基本都是在最后一步通不过,除非重装操作系统,究其原因就是系统里的注册表没有删除干净
- 通过jsonp简单获取接口数据,对了,注意下jsonp方法会自动添加callback<template><div clas
- 什么是生产者消费者模型在 工作中,大家可能会碰到这样一种情况:某个模块负责产生数据,这些数据由另一个模块来负责处理(此处的模块是广义的,可以
- CSS styles和HTML styles有什么区别?HTM style是指自定义HTML标识中一些标签,例如说在HTML中〈B〉〈/B〉