欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Go pprof內(nèi)存指標(biāo)含義備忘錄及案例分析

 更新時(shí)間:2020年03月10日 09:38:05   作者:yoko blog  
這篇文章主要介紹了Go pprof內(nèi)存指標(biāo)含義備忘錄問(wèn)題,小編特此把問(wèn)題及案例分享到腳本之家平臺(tái)供大家學(xué)習(xí),需要的朋友可以參考下

最近組內(nèi)一些Go服務(wù)碰到內(nèi)存相關(guān)的問(wèn)題,所以今天抽時(shí)間看了下Go pprof內(nèi)存指標(biāo)的含義,為后續(xù)查問(wèn)題做準(zhǔn)備。

內(nèi)容主要來(lái)自于Go代碼中對(duì)這些字段的注釋?zhuān)幼约旱睦斫狻@斫獠粚?duì)的地方歡迎指正。

// https://github.com/golang/go/blob/master/src/runtime/mstats.go#L150

// 總共從OS申請(qǐng)的字節(jié)數(shù)
// 是下面各種XxxSys指標(biāo)的總和。包含運(yùn)行時(shí)的heap、stack和其他內(nèi)部數(shù)據(jù)結(jié)構(gòu)的總和。
// 它是虛擬內(nèi)存空間。不一定全部映射成了物理內(nèi)存。
Sys

// 見(jiàn)`Sys`
HeapSys

// 還在使用的對(duì)象,以及不使用還沒(méi)被GC釋放的對(duì)象的字節(jié)數(shù)
// 平時(shí)應(yīng)該平緩,gc時(shí)可能出現(xiàn)鋸齒
HeapAlloc

// 正在使用的對(duì)象字節(jié)數(shù)。
// 有個(gè)細(xì)節(jié)是,如果一個(gè)span中可包含多個(gè)object,只要一個(gè)object在使用,那么算的是整個(gè)span。
// `HeapInuse` - `HeapAlloc`是GC中保留,可以快速被使用的內(nèi)存。
HeapInuse

// 已歸還給OS的內(nèi)存。沒(méi)被堆再次申請(qǐng)的內(nèi)存。
HeapReleased

// 沒(méi)被使用的span的字節(jié)數(shù)。
// 這部分內(nèi)存可以被歸還給OS,并且還包含了`HeapReleased`。
// 可以被再次申請(qǐng),甚至作為棧內(nèi)存使用。
// `HeapIdle` - `HeapReleased`即GC保留的。
HeapIdle

/// ---

// 和`HeapAlloc`一樣
Alloc

// 累計(jì)的`Alloc`
// 累計(jì)的意思是隨程序啟動(dòng)后一直累加增長(zhǎng),永遠(yuǎn)不會(huì)下降。
TotalAlloc

// 沒(méi)什么卵用
Lookups = 0

// 累計(jì)分配的堆對(duì)象數(shù)
Mallocs

// 累計(jì)釋放的堆對(duì)象數(shù)
Frees

// 存活的對(duì)象數(shù)。見(jiàn)`HeapAlloc`
// HeapObjects = `Mallocs` - `Frees`
HeapObjects

// ---
// 下面的XxxInuse中的Inuse的含義,和XxxSys中的Sys的含義,基本和`HeapInuse`和`HeapSys`是一樣的
// 沒(méi)有XxxIdle,是因?yàn)槎及赻HeapIdle`里了

// StackSys基本就等于StackInuse,再加上系統(tǒng)線程級(jí)別的棧內(nèi)存
Stack = StackInuse / StackSys

// 為MSpan結(jié)構(gòu)體使用的內(nèi)存
MSpan = MSpanInuse / MSpanSys

// 為MCache結(jié)構(gòu)體使用的內(nèi)存
MCache = MCacheInuse / MCacheSys

// 下面幾個(gè)都是底層內(nèi)部數(shù)據(jù)結(jié)構(gòu)用到的XxxSys的內(nèi)存統(tǒng)計(jì)
BuckHashSys
GCSys
OtherSys

// ---
// 下面是跟GC相關(guān)的

// 下次GC的觸發(fā)閾值,當(dāng)HeapAlloc達(dá)到這個(gè)值就要GC了
NextGC

// 最近一次GC的unix時(shí)間戳
LastGC

// 每個(gè)周期中GC的開(kāi)始unix時(shí)間戳和結(jié)束unix時(shí)間戳
// 一個(gè)周期可能有0次GC,也可能有多次GC,如果是多次,只記錄最后一個(gè)
PauseNs
PauseEnd

// GC次數(shù)
NumGC

// 應(yīng)用程序強(qiáng)制GC的次數(shù)
NumForcedGC

// GC總共占用的CPU資源。在0~1之間
GCCPUFraction

// 沒(méi)被使用,忽略就好
DebugGC

查看方式

// 方式一
import "runtime"

var m runtime.MemStats
runtime.ReadMemStats(&m)
// 方式二
import _ "net/http/pprof"
import "net/http"
http.ListenAndServe("0.0.0.0:10001", nil)
// http://127.0.0.1:10001/debug/pprof/heap?debug=1

下面隨便找個(gè)服務(wù)來(lái)練手。

Top查看程序的 VIRT 約為2.4G, RES 約為1.7G。

使用web pprof觀察到的指標(biāo),可以對(duì)應(yīng)著前文說(shuō)的含義看看。

# Sys = 1842916040 ~1.7G
# HeapSys = 1711013888 ~1.6G
# HeapInuse = 1237483520 ~1.18G
# HeapAlloc = 1195472528 ~1.14G
HeapInuse - HeapAlloc = 40M
# HeapIdle = 473530368 ~451M
# HeapReleased = 61063168 ~58.2M
HeapIdle - HeapReleased = 393M

# Alloc = 1195472528 ~1.14G
# TotalAlloc = 426616278424 ~397.3G

# Lookups = 0
# Mallocs = 2907819388 ~29億對(duì)象數(shù)
# Frees = 2901808898 ~29億對(duì)象數(shù)
# HeapObjects = 6010490 ~601萬(wàn)對(duì)象數(shù)

# Stack = 33390592 / 33390592 ~31.8M / 31.8M
# MSpan = 13542744 / 19906560 ~12.9M / 18.9M
# MCache = 55552 / 65536
# BuckHashSys = 2371870
# GCSys = 69398992
# OtherSys = 6768602

總結(jié)

到此這篇關(guān)于Go pprof內(nèi)存指標(biāo)含義備忘錄及案例分析的文章就介紹到這了,更多相關(guān)Go pprof內(nèi)存指標(biāo)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Go語(yǔ)言中結(jié)構(gòu)體與JSON間的轉(zhuǎn)換

    詳解Go語(yǔ)言中結(jié)構(gòu)體與JSON間的轉(zhuǎn)換

    這篇文章主要為大家詳細(xì)介紹了Go語(yǔ)言中結(jié)構(gòu)體與JSON間的轉(zhuǎn)換,文中的示例代碼講解詳細(xì),對(duì)學(xué)習(xí)Go語(yǔ)言有一定的幫助,需要的可以參考一下
    2022-12-12
  • Go語(yǔ)言編譯時(shí)為exe添加圖標(biāo)和屬性信息的方法

    Go語(yǔ)言編譯時(shí)為exe添加圖標(biāo)和屬性信息的方法

    在使用Go語(yǔ)言開(kāi)發(fā)應(yīng)用程序時(shí),有個(gè)非常方便的地方就是編譯得到的可執(zhí)行文件可以不依賴(lài)任何動(dòng)態(tài)鏈接庫(kù)、并且不需要任何運(yùn)行環(huán)境即可運(yùn)行,本文給大家介紹Go編譯時(shí)為exe添加圖標(biāo)和屬性信息的方法,需要的朋友可以參考下
    2023-09-09
  • Go語(yǔ)言中常用的基礎(chǔ)方法總結(jié)

    Go語(yǔ)言中常用的基礎(chǔ)方法總結(jié)

    這篇文章主要為大家詳細(xì)介紹了Go語(yǔ)言中常用的一些基礎(chǔ)方法,例如:使用正則表達(dá)式驗(yàn)證字符串、格式化字符串、時(shí)間的比較等等,需要的可以參考一下
    2022-09-09
  • Go語(yǔ)言reflect包的反射機(jī)制基本用法示例

    Go語(yǔ)言reflect包的反射機(jī)制基本用法示例

    反射在處理接口和類(lèi)型斷言、開(kāi)發(fā)通用功能或者設(shè)計(jì)框架時(shí)尤為重要,本文將深入探索 Go 語(yǔ)言中的反射機(jī)制,通過(guò)具體的示例展示如何使用?reflect?包,讓你能夠在 Go 項(xiàng)目中有效地利用這一強(qiáng)大的工具
    2023-11-11
  • 手把手教你導(dǎo)入Go語(yǔ)言第三方庫(kù)

    手把手教你導(dǎo)入Go語(yǔ)言第三方庫(kù)

    本文主要介紹了手把手教你導(dǎo)入Go語(yǔ)言第三方庫(kù),通過(guò)導(dǎo)入gin包來(lái)深入學(xué)習(xí),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 詳解Golang開(kāi)啟http服務(wù)的三種方式

    詳解Golang開(kāi)啟http服務(wù)的三種方式

    這篇文章主要介紹了詳解Golang開(kāi)啟http服務(wù)的三種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • vim配置go語(yǔ)言語(yǔ)法高亮問(wèn)題的解決方法

    vim配置go語(yǔ)言語(yǔ)法高亮問(wèn)題的解決方法

    vim配置go語(yǔ)言語(yǔ)法高亮的問(wèn)題已經(jīng)遇到過(guò)好幾次了,每次都是找不到答案,今天小編給大家?guī)?lái)了vim配置go語(yǔ)言語(yǔ)法高亮問(wèn)題的解決方法,感興趣的朋友一起看看吧
    2018-01-01
  • SingleFlight模式的Go并發(fā)編程學(xué)習(xí)

    SingleFlight模式的Go并發(fā)編程學(xué)習(xí)

    這篇文章主要為大家介紹了SingleFlight模式的Go并發(fā)編程學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-04-04
  • Go Java算法之同構(gòu)字符串示例詳解

    Go Java算法之同構(gòu)字符串示例詳解

    這篇文章主要為大家介紹了Go Java算法之同構(gòu)字符串示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • golang HTTP 服務(wù)器 處理 日志/Stream流的操作

    golang HTTP 服務(wù)器 處理 日志/Stream流的操作

    這篇文章主要介紹了golang HTTP 服務(wù)器 處理 日志/Stream流的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-12-12

最新評(píng)論