【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
  • 前言 當別人做大數據用Java、Python的時候,我使用.NET做大數據、數據挖掘,這確實是值得一說的事。 寫的並不全面,但都是實際工作中的內容。 .NET在大數據項目中,可以做什麼? 寫腳本(使用控制台程式+頂級語句) 寫工具(使用Winform) 寫介面、寫服務 使用C#寫代碼的優點是什麼? ...
  • 前言 本文寫給想學C#的朋友,目的是以儘快的速度入門 C#好學嗎? 對於這個問題,我以前的回答是:好學!但仔細想想,不是這麼回事,對於新手來說,C#沒有那麼好學。 反而學Java還要容易一些,學Java Web就行了,就是SpringBoot那一套。 但是C#方向比較多,你是學控制台程式、WebAP ...
  • 某一日晚上上線,測試同學在回歸項目黃金流程時,有一個工單項目介面報JSF序列化錯誤,馬上升級對應的client包版本,編譯部署後錯誤消失。 線上問題是解決了,但是作為程式員要瞭解問題發生的原因和本質。但這都是為什麼呢? ...
  • 本文介紹基於Python語言中TensorFlow的Keras介面,實現深度神經網路回歸的方法。 1 寫在前面 前期一篇文章Python TensorFlow深度學習回歸代碼:DNNRegressor詳細介紹了基於TensorFlow tf.estimator介面的深度學習網路;而在TensorFl ...
  • 前段時間因業務需要完成了一個工作流組件的編碼工作。藉著這個機會跟大家分享一下整個創作過程,希望大家喜歡,組件暫且命名為"easyFlowable"。 接下來的文章我將從什麼是工作流、為什麼要自研這個工作流組件、架構設計三個維度跟大家來做個整體介紹。 ...
  • 1 簡介 我們之前使用了dapr的本地托管模式,但在生產中我們一般使用Kubernetes托管,本文介紹如何在GKE(GCP Kubernetes)安裝dapr。 相關文章: dapr本地托管的服務調用體驗與Java SDK的Spring Boot整合 dapr入門與本地托管模式嘗試 2 安裝GKE ...
  • 摘要:在jvm中有很多的參數可以進行設置,這樣可以讓jvm在各種環境中都能夠高效的運行。絕大部分的參數保持預設即可。 本文分享自華為雲社區《為什麼需要對jvm進行優化,jvm運行參數之標準參數》,作者:共飲一杯無。 我們為什麼要對jvm做優化? 在本地開發環境中我們很少會遇到需要對jvm進行優化的需 ...
  • 背景 我們的業務共使用11台(阿裡雲)伺服器,使用SpringcloudAlibaba構建微服務集群,共計60個微服務,全部註冊在同一個Nacos集群 流量轉發路徑: nginx->spring-gateway->業務微服務 使用的版本如下: spring-boot.version:2.2.5.RE ...
  • 基於php+webuploader的大文件分片上傳,帶進度條,支持斷點續傳(刷新、關閉頁面、重新上傳、網路中斷等情況)。文件上傳前先檢測該文件是否已上傳,如果已上傳提示“文件已存在”,如果未上傳則直接上傳。視頻上傳時會根據設定的參數(分片大小、分片數量)進行上傳,上傳過程中會在目標文件夾中生成一個臨 ...
  • 基於php大文件分片上傳至七牛雲,使用的是七牛雲js-sdk V2版本,引入js文件,配置簡單,可以暫停,暫停後支持斷點續傳(刷新、關閉頁面、重新上傳、網路中斷等情況),可以配置分片大小和分片數量,官方文檔https://developer.qiniu.com/kodo/6889/javascrip ...