婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Go程序性能優化及pprof使用方法詳解

Go程序性能優化及pprof使用方法詳解

熱門標簽:浙江高頻外呼系統多少錢一個月 濱州自動電銷機器人排名 建造者2地圖標注 惠州電銷防封電話卡 汕頭小型外呼系統 釘釘有地圖標注功能嗎 鄭州亮點科技用的什么外呼系統 阿里云ai電話機器人 黃岡人工智能電銷機器人哪個好

Go 程序的性能優化及 pprof 的使用

程序的性能優化無非就是對程序占用資源的優化。對于服務器而言,最重要的兩項資源莫過于 CPU 和內存。性能優化,就是在對于不影響程序數據處理能力的情況下,我們通常要求程序的 CPU 的內存占用盡量低。反過來說,也就是當程序 CPU 和內存占用不變的情況下,盡量地提高程序的數據處理能力或者說是吞吐量。

Go 的原生工具鏈中提供了非常多豐富的工具供開發者使用,其中包括 pprof。

對于 pprof 的使用要分成下面兩部分來說。

Web 程序使用 pprof

先寫一個簡單的 Web 服務程序。程序在 9876 端口上接收請求。

package main

import (
  "bytes"
  "io/ioutil"
  "log"
  "math/rand"
  "net/http"

  _ "net/http/pprof"
)

func main() {
  http.HandleFunc("/test", handler)
  log.Fatal(http.ListenAndServe(":9876", nil))
}

func handler(w http.ResponseWriter, r *http.Request) {
  err := r.ParseForm()
  if nil != err {
    w.Write([]byte(err.Error()))
    return
  }
  doSomeThingOne(10000)
  buff := genSomeBytes()
  b, err := ioutil.ReadAll(buff)
  if nil != err {
    w.Write([]byte(err.Error()))
    return
  }
  w.Write(b)
}

func doSomeThingOne(times int) {
  for i := 0; i  times; i++ {
    for j := 0; j  times; j++ {

    }
  }
}

func genSomeBytes() *bytes.Buffer {
  var buff bytes.Buffer
  for i := 1; i  20000; i++ {
    buff.Write([]byte{'0' + byte(rand.Intn(10))})
  }
  return buff
}

可以看到我們只是簡單地引入了 net/http/pprof ,并未顯示地使用。

啟動程序。

我們用 wrk 來簡單地模擬請求。

wrk -c 400 -t 8 -d 3m http://localhost:9876/test

這時我們打開 http://localhost:9876/debug/pprof,會顯示如下頁面:

用戶可以點擊相應的鏈接瀏覽內容。不過這不是我們重點講述的,而且這些內容看起來并不直觀。

我們打開鏈接 http://localhost:9876/debug/pprof/profile 稍后片刻,可以下載到文件 profile。

使用 Go 自帶的 pprof 工具打開。go tool pprof test profile。(proof 后跟的 test 為程序編譯的可執行文件)

輸入 top 命令得到:

可以看到 cpu 占用前 10 的函數,我們可以對此分析進行優化。

只是這樣可能還不是很直觀。

我們輸入命令 web(需要事先安裝 graphviz,macOS 下可以 brew install graphviz),會在瀏覽器中打開界面如下:

可以看到 main.doSomeThingOne 占用了 92.46% 的 CPU 時間,需要對其進行優化。

Web 形式的 CPU 時間圖對于優化已經完全夠用,這邊再介紹一下火焰圖的生成。macOS 推薦使用 go-torch 工具。使用方法和 go tool pprof 相似。

go-torch test profile 會生成 torch.svg 文件。可以用瀏覽器打開,如圖。

剛才只是講了 CPU 的占用分析文件的生成查看,其實內存快照的生成相似。http://localhost:9876/debug/pprof/heap,會下載得到 heap.gz 文件。

我們同樣可以使用 go tool pprof test heap.gz,然后輸入 top web 命令查看相關內容。

通用程序使用 pprof

我們寫的 Go 程序并非都是 Web 程序,這時候再使用上面的方法就不行了。

我們仍然可以使用 pprof 工具,但引入的位置為 runtime/pprof

這里貼出兩個函數,作為示例:

// 生成 CPU 報告
func cpuProfile() {
  f, err := os.OpenFile("cpu.prof", os.O_RDWR|os.O_CREATE, 0644)
  if err != nil {
    log.Fatal(err)
  }
  defer f.Close()

  log.Println("CPU Profile started")
  pprof.StartCPUProfile(f)
  defer pprof.StopCPUProfile()

  time.Sleep(60 * time.Second)
  fmt.Println("CPU Profile stopped")
}

// 生成堆內存報告
func heapProfile() {
  f, err := os.OpenFile("heap.prof", os.O_RDWR|os.O_CREATE, 0644)
  if err != nil {
    log.Fatal(err)
  }
  defer f.Close()

  time.Sleep(30 * time.Second)

  pprof.WriteHeapProfile(f)
  fmt.Println("Heap Profile generated")
}

兩個函數分別會生成 cpu.profheap.prof 文件。仍然可以使用 go tool pprof 工具進行分析,在此就不贅述。

Trace 報告

直接貼代碼:

// 生成追蹤報告
func traceProfile() {
  f, err := os.OpenFile("trace.out", os.O_RDWR|os.O_CREATE, 0644)
  if err != nil {
    log.Fatal(err)
  }
  defer f.Close()

  log.Println("Trace started")
  trace.Start(f)
  defer trace.Stop()

  time.Sleep(60 * time.Second)
  fmt.Println("Trace stopped")
}

使用工具 go tool trace 進行分析,會得到非常詳細的追蹤報告,供更深入的程序分析優化。由于報告內容比較復雜,且使用方法類似,就不繼續了。讀者可自行嘗試。

貼張網上的圖給大家大概看一下:

參考:https://github.com/caibirdme/hand-to-hand-optimize-go

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 深入理解Golang的單元測試和性能測試
  • golang利用pprof與go-torch如何做性能分析

標簽:瀘州 駐馬店 東營 阿壩 昭通 晉中 泰安 滄州

巨人網絡通訊聲明:本文標題《Go程序性能優化及pprof使用方法詳解》,本文關鍵詞  程序,性能,優化,及,pprof,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Go程序性能優化及pprof使用方法詳解》相關的同類信息!
  • 本頁收集關于Go程序性能優化及pprof使用方法詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 抚顺市| 卓资县| 长沙市| 麦盖提县| 新晃| 夏津县| 西峡县| 呈贡县| 土默特右旗| 伊金霍洛旗| 桐庐县| 聂拉木县| 宝山区| 芦溪县| 桦南县| 惠来县| 哈巴河县| 娱乐| 龙游县| 甘洛县| 盖州市| 梁山县| 灵丘县| 元阳县| 太仆寺旗| 洪江市| 白玉县| 新田县| 长垣县| 西林县| 汝州市| 吉林市| 金昌市| 张家港市| 来凤县| 宁都县| 邓州市| 嵊州市| 嘉定区| 扬州市| 陕西省|