【golang】pprof性能調優工具的具體使用(帶案例)

来源:https://www.cnblogs.com/freeyw/archive/2022/08/01/16541968.html
-Advertisement-
Play Games

前言 大晚上的,老是刷到有關pprof的文章,忍不住看了幾篇文章...寫個學習筆記記錄下~ 正文: 1.pprof是什麼? pprof是go內置的性能調優工具,可以藉助一些工具以圖形化的方式展示出來某些介面占用cpu資源的詳情。 2.專項用途: 1.cpu 主要測試占用cpu資源比較多的函數或者數據 ...


前言

  大晚上的,老是刷到有關pprof的文章,忍不住看了幾篇文章...寫個學習筆記記錄下~

 

 

 

 

 

 

 

 正文:

 1.pprof是什麼?

  pprof是go內置的性能調優工具,可以藉助一些工具以圖形化的方式展示出來某些介面占用cpu資源的詳情。

2.專項用途:

  1.cpu

    主要測試占用cpu資源比較多的函數或者數據,可以推出當前程式的熱點數據

  2.記憶體

    主要測試堆記憶體的使用以及分配情況

  3.阻塞

    主要測試goroutine的使用情況,分析系統的併發瓶頸

3.使用方式

  1.命令行

    這個不介紹了,後面都要使用命令行.先看個例子

func readMemStats() {
    // MemStats 描述記憶體信息的靜態變數
    var ms runtime.MemStats
    // 讀取某一時刻記憶體情況的快照
    runtime.ReadMemStats(&ms)
    // alloc占用記憶體情況、堆空閑情況、堆釋放情況
    log.Printf("========> Alloc:%d(bytes) HeapIdle:%d(bytes) HeapReleased:%d(bytes)", ms.Alloc, ms.HeapIdle, ms.HeapReleased)
}

// append的擴容情況 func test() { container :
= make([]int, 8) log.Println("========> loop begin .") // 追加元素 for i := 0; i < 32*1000*1000; i++ { container = append(container, i) if i == 16*1000*1000 { readMemStats() } } log.Println("==========> loop end.") } func main() { log.Println("============> [start].")
// 開始時候的記憶體占用情況 readMemStats()
// 調用append時候的情況 test() readMemStats() log.Println(
"============> [force.gc].") // 強制開啟gc runtime.GC() log.Println("===========>[Done] .") readMemStats() go func() { for { readMemStats() time.Sleep(10 * time.Second) } }() time.Sleep(3600 * time.Second) }

 

 看下具體情況:

  

 

 

 上面顯示的參數中可以看到記憶體的使用情況。分別是分配、空閑、釋放

我們可以也可以通過訪問相應的地址,在界面上看到相應的信息,來看下一種方式:

2.網路方式

  只需要在上面代碼加入監聽語句,並導入 net/http/pprof庫即可。下麵是僅僅展示了main函數部分

import (
    "log"
    "net/http"
    _ "net/http/pprof"
    "runtime"
    "time"
)

func main() {
    // 啟動 pprof,這種是採用網路監聽的方式,可以通過訪問界面顯示出測試的數據
    go func() {
        log.Println(http.ListenAndServe("localhost:8080", nil))
    }()
    log.Println("============> [start].")
    readMemStats()
    test()
    readMemStats()
    log.Println("============> [force.gc].")
    // 強制開啟gc
    runtime.GC()
    log.Println("===========>[Done] .")
    readMemStats()
    go func() {
        for {
            readMemStats()
            time.Sleep(10 * time.Second)
        }
    }()
    time.Sleep(3600 * time.Second)
}

下麵讓我們來執行下:

  運行程式後,訪問上面路徑的時候可以加上 /debug/pprof。這個是pprof預設的網頁地址,當然不止這一個,其他的大家可以查詢下,我就不過多介紹了~

 

 

 我們可以在下麵看到各個文件的解釋,圈起來的是有關cpu性能分析的文件。我們可以點擊下載下。

3.互動式

1.首先我們把剛纔下載的cpu相關的文件,移動到當前目錄下

2.然後執行:

  

 

 

 蕪湖~起飛.這個時候我們已經進入交互模式,輸入 top 查看當前程式的執行情況

 

 

 涉及的參數的意思,大家可以私下去查詢下~

如果想要以圖形化的方式展示呢,輸入web:

 

 

 可以看到相關的分析圖,方框越大,占用cpu資源越多喲~

如果輸入web,顯示沒有svg的話,可以下載 graphviz。配置好環境變數後,重啟電腦,再次輸入web即可

好了,關於pprof的簡單使用就到這裡嘍,對了上面的程式參考的是這裡 : https://www.bookstack.cn/read/aceld-golang/README.md

下次再見~

|不驕不躁,保持學習


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 作者:vivo 互聯網中間件團隊- Liu Runyun 大量業務使用消息中間件進行系統間的解耦、非同步化、削峰填谷設計實現。公司內部前期基於RabbitMQ實現了一套高可用的消息中間件平臺。隨著業務的持續增長,消息體量隨之增大,對消息中間件平臺提出了更高的要求,此外在運維過程中也遇到了高可用難以保障 ...
  • 詳情請見:CSDN 阿史大杯茶 https://blog.csdn.net/weixin_66946161/article/details/126093709 題目意思 本題主要意思就是切成 一個個小塊(小塊的面積相同,但小塊不相同),使小塊之間互不相等,而且旋轉之後相同,也算小塊相同!例: AB ...
  • 一、Git介紹 1.Git是什麼? Git是一個免費的、開源的分散式版本控制系統,可以有效、高速地處理從很小到非常大的項目版本管理。 2.Git能做什麼? 從伺服器上克隆完整的Git倉庫(包括代碼和版本信息)到單機上。 在自己的機器上根據不同的開發目的,創建分支,修改代碼。 在單機上自己創建的分支上 ...
  • 編寫程式過程中難免出錯。程式錯誤可分為三類,它們分別是語法錯誤、語義錯誤(或稱邏輯錯誤)和運行時錯誤。針對不同錯誤,C++語言具有不同的解決辦法,最終保證所開發的程式能夠正確、穩定地運行。針對程式運行時的錯誤C++設計了專門的異常處理機制,即try-catch機制。C++標準庫為異常處理機制提供多種 ...
  • 目錄 一.簡介 二.效果演示 三.源碼下載 四.猜你喜歡 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 基礎 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 轉場 零基礎 O ...
  • A. Two 0-1 Sequences 大致翻譯: 兩個長度為n和m的二進位序列a和b(題目保證n >= m) 兩個操作: op1: 改變a(2) 為min(a(1), a(2)),並且移除a(1) op2: 改變a(2) 為max(a(1), a(2)),並且移除a(1) 每次操作後,原先的a( ...
  • TableGo是基於資料庫的自動化生成工具,低代碼編程技術的實現,全能代碼生成器,自動生成項目框架、生成JavaBean、生成前後端代碼、生成資料庫文檔、生成API文檔、自動化部署項目、能查出資料庫數據生成各種代碼和文檔等,更重要的是可以根據每個項目的不同開發框架編寫自定義模板與項目框架適配生成各模... ...
  • 精華筆記: 1. 迴圈結構: - for結構:應用率高、與次數相關的迴圈 ```java 1)語法: // 1 2 3 for(要素1;要素2;要素3){ 語句塊/迴圈體 反覆執行的語句 4 } 2)執行過程: 1243243243243243...2 ``` 2. 三種迴圈結構如何選擇: - 先看 ...
一周排行
    -Advertisement-
    Play Games
  • Timer是什麼 Timer 是一種用於創建定期粒度行為的機制。 與標準的 .NET System.Threading.Timer 類相似,Orleans 的 Timer 允許在一段時間後執行特定的操作,或者在特定的時間間隔內重覆執行操作。 它在分散式系統中具有重要作用,特別是在處理需要周期性執行的 ...
  • 前言 相信很多做WPF開發的小伙伴都遇到過表格類的需求,雖然現有的Grid控制項也能實現,但是使用起來的體驗感並不好,比如要實現一個Excel中的表格效果,估計你能想到的第一個方法就是套Border控制項,用這種方法你需要控制每個Border的邊框,並且在一堆Bordr中找到Grid.Row,Grid. ...
  • .NET C#程式啟動閃退,目錄導致的問題 這是第2次踩這個坑了,很小的編程細節,容易忽略,所以寫個博客,分享給大家。 1.第一次坑:是windows 系統把程式運行成服務,找不到配置文件,原因是以服務運行它的工作目錄是在C:\Windows\System32 2.本次坑:WPF桌面程式通過註冊表設 ...
  • 在分散式系統中,數據的持久化是至關重要的一環。 Orleans 7 引入了強大的持久化功能,使得在分散式環境下管理數據變得更加輕鬆和可靠。 本文將介紹什麼是 Orleans 7 的持久化,如何設置它以及相應的代碼示例。 什麼是 Orleans 7 的持久化? Orleans 7 的持久化是指將 Or ...
  • 前言 .NET Feature Management 是一個用於管理應用程式功能的庫,它可以幫助開發人員在應用程式中輕鬆地添加、移除和管理功能。使用 Feature Management,開發人員可以根據不同用戶、環境或其他條件來動態地控制應用程式中的功能。這使得開發人員可以更靈活地管理應用程式的功 ...
  • 在 WPF 應用程式中,拖放操作是實現用戶交互的重要組成部分。通過拖放操作,用戶可以輕鬆地將數據從一個位置移動到另一個位置,或者將控制項從一個容器移動到另一個容器。然而,WPF 中預設的拖放操作可能並不是那麼好用。為瞭解決這個問題,我們可以自定義一個 Panel 來實現更簡單的拖拽操作。 自定義 Pa ...
  • 在實際使用中,由於涉及到不同編程語言之間互相調用,導致C++ 中的OpenCV與C#中的OpenCvSharp 圖像數據在不同編程語言之間難以有效傳遞。在本文中我們將結合OpenCvSharp源碼實現原理,探究兩種數據之間的通信方式。 ...
  • 一、前言 這是一篇搭建許可權管理系統的系列文章。 隨著網路的發展,信息安全對應任何企業來說都越發的重要,而本系列文章將和大家一起一步一步搭建一個全新的許可權管理系統。 說明:由於搭建一個全新的項目過於繁瑣,所有作者將挑選核心代碼和核心思路進行分享。 二、技術選擇 三、開始設計 1、自主搭建vue前端和. ...
  • Csharper中的表達式樹 這節課來瞭解一下表示式樹是什麼? 在C#中,表達式樹是一種數據結構,它可以表示一些代碼塊,如Lambda表達式或查詢表達式。表達式樹使你能夠查看和操作數據,就像你可以查看和操作代碼一樣。它們通常用於創建動態查詢和解析表達式。 一、認識表達式樹 為什麼要這樣說?它和委托有 ...
  • 在使用Django等框架來操作MySQL時,實際上底層還是通過Python來操作的,首先需要安裝一個驅動程式,在Python3中,驅動程式有多種選擇,比如有pymysql以及mysqlclient等。使用pip命令安裝mysqlclient失敗應如何解決? 安裝的python版本說明 機器同時安裝了 ...