【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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...