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

web項(xiàng)目中g(shù)olang性能監(jiān)控解析

 更新時(shí)間:2022年04月14日 12:51:05   作者:Jeff的技術(shù)棧  
這篇文章主要為大家介紹了web項(xiàng)目中g(shù)olang性能監(jiān)控詳細(xì)的解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪

性能監(jiān)控

一、web項(xiàng)目(如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:訪問這個(gè)鏈接會(huì)自動(dòng)進(jìn)行 CPU profiling,持續(xù) 30s,并生成一個(gè)文件供下載
/debug/pprof/block:Goroutine阻塞事件的記錄。默認(rèn)每發(fā)生一次阻塞事件時(shí)取樣一次。
/debug/pprof/goroutines:活躍Goroutine的信息的記錄。僅在獲取時(shí)取樣一次。
/debug/pprof/heap: 堆內(nèi)存分配情況的記錄。默認(rèn)每分配512K字節(jié)時(shí)取樣一次。
/debug/pprof/mutex: 查看爭(zhēng)用互斥鎖的持有者。
/debug/pprof/threadcreate: 系統(tǒng)線程創(chuàng)建情況的記錄。 僅在獲取時(shí)取樣一次。

二、單個(gè)的go文件如果查看gc

1.設(shè)置環(huán)境變量

set GODEBUG=gctrace=1

2.術(shù)語(yǔ):

mark:標(biāo)記階段。

markTermination:標(biāo)記結(jié)束階段。

mutator assist:輔助 GC,是指在 GC 過(guò)程中 mutator 線程會(huì)并發(fā)運(yùn)行,而 mutator assist 機(jī)制會(huì)協(xié)助 GC 做一部分的工作。

heaplive:在 Go 的內(nèi)存管理中,span 是內(nèi)存頁(yè)的基本單元,每頁(yè)大小為 8kb,同時(shí) Go 會(huì)根據(jù)對(duì)象的大小不同而分配不同頁(yè)數(shù)的 span,而 heaplive 就代表著所有 span 的總大小。

dedicated / fractional / idle:在標(biāo)記階段會(huì)分為三種不同的 mark worker 模式,分別是 dedicated、fractional 和 idle,它們代表著不同的專注程度,其中 dedicated 模式最專注,是完整的 GC 回收行為,fractional 只會(huì)干部分的 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 執(zhí)行次數(shù)的編號(hào),每次疊加。第4次 GC。
  • @0.254s:自程序啟動(dòng)后到當(dāng)前的具體秒數(shù)。:當(dāng)前是程序啟動(dòng)后的 0.254s。
  • 5%:自程序啟動(dòng)以來(lái)在GC中花費(fèi)的時(shí)間百分比。程序啟動(dòng)后到現(xiàn)在共花費(fèi) 5% 的時(shí)間在 GC 上
  • 2.0+1.0+9.9ms clock:GC 的標(biāo)記工作共使用的 CPU 時(shí)間占總 CPU 時(shí)間的百分比。
  • 2.0表示單個(gè) P 在 mark 階段的 STW 時(shí)間。(stop the world)
  • 1.0表示所有 P 的 mark concurrent(并發(fā)標(biāo)記)所使用的時(shí)間。
  • 9.9表示單個(gè) P 的 markTermination 階段的 STW 時(shí)間
  • 16+0/2.0/2.0+79 ms cpu
  • 16:表示整個(gè)進(jìn)程在 mark 階段 STW 停頓的時(shí)間。
  • 0/2.0/2.0:0表示 mutator assist 占用的時(shí)間,2.0表示 dedicated + fractional 占用的時(shí)間,2.0 表示 idle 占用的時(shí)間。
  • 4->4->0 MB
  • 4表示開始 mark 階段前的 heap_live 大小。
  • 4表示開始 markTermination 階段前的 heap_live 大小。
  • 1表示被標(biāo)記對(duì)象的大小。
  • 5 MB goal:表示下一次觸發(fā) GC 回收的閾值是 5 MB。
  • 8 P:本次 GC 一共涉及多少個(gè) P

查看電腦的配置:

  • 運(yùn)行-- dxdiag
  • 設(shè)備管理器

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

  • inuse: 111,:使用多少M(fèi)內(nèi)存
  • idle: 54,:0 剩下要清除的內(nèi)存
  • sys: 187,: 系統(tǒng)映射的內(nèi)存
  • released: 0,: 釋放的系統(tǒng)內(nèi)存
  • consumed: 198: 申請(qǐng)的系統(tǒng)內(nèi)存

以上就是web項(xiàng)目中g(shù)olang性能監(jiān)控解析的詳細(xì)內(nèi)容,更多關(guān)于web中g(shù)olang性能監(jiān)控的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • go語(yǔ)言LeetCode題解944刪列造序示例詳解

    go語(yǔ)言LeetCode題解944刪列造序示例詳解

    這篇文章主要為大家介紹了go語(yǔ)言LeetCode題解944刪列造序示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • 在Golang中使用iota案例詳解

    在Golang中使用iota案例詳解

    在Go語(yǔ)言中,iota是一個(gè)預(yù)定義的標(biāo)識(shí)符,用于在常量聲明中生成連續(xù)的遞增值,iota的值從0開始,每次在常量聲明中使用時(shí)遞增,本就給大家講解一下Golang中iota的使用案例,感興趣的同學(xué)跟著小編一起來(lái)看看吧
    2023-07-07
  • Go語(yǔ)言編譯程序從后臺(tái)運(yùn)行,不出現(xiàn)dos窗口的操作

    Go語(yǔ)言編譯程序從后臺(tái)運(yùn)行,不出現(xiàn)dos窗口的操作

    這篇文章主要介紹了Go語(yǔ)言編譯程序從后臺(tái)運(yùn)行,不出現(xiàn)dos窗口的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-04-04
  • go1.21中slog日志包用法入門

    go1.21中slog日志包用法入門

    go1.21中,slog這一被Go語(yǔ)言團(tuán)隊(duì)精心設(shè)計(jì)的結(jié)構(gòu)化日志包正式落地,本文將帶領(lǐng)讀者上手slog,體會(huì)其與傳統(tǒng)log的差異,感興趣的小伙伴快跟隨小編一起學(xué)習(xí)一下吧
    2023-09-09
  • Golang 處理浮點(diǎn)數(shù)遇到的精度問題(使用decimal)

    Golang 處理浮點(diǎn)數(shù)遇到的精度問題(使用decimal)

    本文主要介紹了Golang 處理浮點(diǎn)數(shù)遇到的精度問題,不使用decimal會(huì)出大問題,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • Golang實(shí)現(xiàn)http重定向https

    Golang實(shí)現(xiàn)http重定向https

    這篇文章介紹了Golang實(shí)現(xiàn)http重定向https的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • Go高級(jí)特性之并發(fā)處理http詳解

    Go高級(jí)特性之并發(fā)處理http詳解

    Golang?作為一種高效的編程語(yǔ)言,提供了多種方法來(lái)實(shí)現(xiàn)并發(fā)發(fā)送?HTTP?請(qǐng)求,本文將深入探討?Golang?中并發(fā)發(fā)送?HTTP?請(qǐng)求的最佳技術(shù)和實(shí)踐,希望對(duì)大家有所幫助
    2024-02-02
  • Go type關(guān)鍵字(類型定義與類型別名的使用差異)用法實(shí)例探究

    Go type關(guān)鍵字(類型定義與類型別名的使用差異)用法實(shí)例探究

    這篇文章主要為大家介紹了Go type關(guān)鍵字(類型定義與類型別名的使用差異)用法實(shí)例探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2024-01-01
  • golang?對(duì)象深拷貝的常見方式及性能

    golang?對(duì)象深拷貝的常見方式及性能

    這篇文章主要介紹了golang?對(duì)象深拷貝的常見方式及性能,Go語(yǔ)言中所有賦值操作都是值傳遞,如果結(jié)構(gòu)中不含指針,則直接賦值就是深度拷貝,文章圍繞主題展開更多相關(guān)資料,需要的小伙伴可以參考一下
    2022-06-06
  • Golang中的錯(cuò)誤處理的示例詳解

    Golang中的錯(cuò)誤處理的示例詳解

    這篇文章主要為大家詳細(xì)介紹了Golang中的錯(cuò)誤處理的相關(guān)資料,文章中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Golang有一定幫助,需要的可以參考一下
    2022-12-12

最新評(píng)論