web項目中g(shù)olang性能監(jiān)控解析
性能監(jiān)控
一、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:訪問這個鏈接會自動進(jìn)行 CPU profiling,持續(xù) 30s,并生成一個文件供下載 /debug/pprof/block:Goroutine阻塞事件的記錄。默認(rèn)每發(fā)生一次阻塞事件時取樣一次。 /debug/pprof/goroutines:活躍Goroutine的信息的記錄。僅在獲取時取樣一次。 /debug/pprof/heap: 堆內(nèi)存分配情況的記錄。默認(rèn)每分配512K字節(jié)時取樣一次。 /debug/pprof/mutex: 查看爭用互斥鎖的持有者。 /debug/pprof/threadcreate: 系統(tǒng)線程創(chuàng)建情況的記錄。 僅在獲取時取樣一次。
二、單個的go文件如果查看gc
1.設(shè)置環(huán)境變量
set GODEBUG=gctrace=1
2.術(shù)語:
mark:標(biāo)記階段。
markTermination:標(biāo)記結(jié)束階段。
mutator assist:輔助 GC,是指在 GC 過程中 mutator 線程會并發(fā)運行,而 mutator assist 機(jī)制會協(xié)助 GC 做一部分的工作。
heaplive:在 Go 的內(nèi)存管理中,span 是內(nèi)存頁的基本單元,每頁大小為 8kb,同時 Go 會根據(jù)對象的大小不同而分配不同頁數(shù)的 span,而 heaplive 就代表著所有 span 的總大小。
dedicated / fractional / idle:在標(biāo)記階段會分為三種不同的 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 執(zhí)行次數(shù)的編號,每次疊加。第4次 GC。
- @0.254s:自程序啟動后到當(dāng)前的具體秒數(shù)。:當(dāng)前是程序啟動后的 0.254s。
- 5%:自程序啟動以來在GC中花費的時間百分比。程序啟動后到現(xiàn)在共花費 5% 的時間在 GC 上
- 2.0+1.0+9.9ms clock:GC 的標(biāo)記工作共使用的 CPU 時間占總 CPU 時間的百分比。
- 2.0表示單個 P 在 mark 階段的 STW 時間。(stop the world)
- 1.0表示所有 P 的 mark concurrent(并發(fā)標(biāo)記)所使用的時間。
- 9.9表示單個 P 的 markTermination 階段的 STW 時間
- 16+0/2.0/2.0+79 ms cpu
- 16:表示整個進(jìn)程在 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表示被標(biāo)記對象的大小。
- 5 MB goal:表示下一次觸發(fā) GC 回收的閾值是 5 MB。
- 8 P:本次 GC 一共涉及多少個 P
查看電腦的配置:
- 運行-- dxdiag
- 設(shè)備管理器
scvg4: inuse: 111, idle: 54, sys: 187, released: 0, consumed: 198 (MB)
- inuse: 111,:使用多少M內(nèi)存
- idle: 54,:0 剩下要清除的內(nèi)存
- sys: 187,: 系統(tǒng)映射的內(nèi)存
- released: 0,: 釋放的系統(tǒng)內(nèi)存
- consumed: 198: 申請的系統(tǒng)內(nèi)存
以上就是web項目中g(shù)olang性能監(jiān)控解析的詳細(xì)內(nèi)容,更多關(guān)于web中g(shù)olang性能監(jiān)控的資料請關(guān)注腳本之家其它相關(guān)文章!
- golang調(diào)試bug及性能監(jiān)控方式實踐總結(jié)
- golang?pprof?監(jiān)控goroutine?thread統(tǒng)計原理詳解
- golang?pprof監(jiān)控memory?block?mutex統(tǒng)計原理分析
- golang?pprof監(jiān)控memory?block?mutex使用指南
- golang?pprof?監(jiān)控系列?go?trace統(tǒng)計原理與使用解析
- prometheus?client_go為應(yīng)用程序自定義監(jiān)控指標(biāo)
- Go語言metrics應(yīng)用監(jiān)控指標(biāo)基本使用說明
- Skywalking-go自動監(jiān)控增強(qiáng)使用探究
相關(guān)文章
Go語言編譯程序從后臺運行,不出現(xiàn)dos窗口的操作
這篇文章主要介紹了Go語言編譯程序從后臺運行,不出現(xiàn)dos窗口的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-04-04Golang 處理浮點數(shù)遇到的精度問題(使用decimal)
本文主要介紹了Golang 處理浮點數(shù)遇到的精度問題,不使用decimal會出大問題,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02Go type關(guān)鍵字(類型定義與類型別名的使用差異)用法實例探究
這篇文章主要為大家介紹了Go type關(guān)鍵字(類型定義與類型別名的使用差異)用法實例探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01