超牛逼!這款開源效能監控系統真強大~

語言: CN / TW / HK

點選 關注 公眾號, 回覆“ 1024 ”獲取 2TB 學習資源!

當網站上線後,流量增加或短暫功能故障,都會造成使用者體驗相當不好,而這時該怎麼快速找到效能的瓶頸呢?通常 CPU 達到 100% 時,有時候也很難複製及找出關鍵問題點。

本篇文章,我們會介紹一套工具叫 Pyroscope,讓開發者可以快速找到效能瓶頸的程式碼。Pyroscope 目前可以支援 Python, Ruby 或 Go 的環境。本文筆者會針對 Go 環境做介紹。

什麼是 Pyroscope?

Pyroscope 是一套開源的效能即時監控平臺,簡單的 Server 及 Agent 架構,讓開發者可以輕鬆監控程式碼效能,不管你要找 10 秒或幾分鐘內的效能資料,都可以快速的即時呈現,開發者也不用在意裝了此監控會造成任何效能上的負擔。Pyroscope 背後的儲存採用 Badger 這套 Key-Value 資料庫,效能上是非常好的。目前只支援 3 種語言 (Python, Ruby 及 Go) 未來會預計支援 NodeJS。假設您還沒引入任何效能分析工具或平臺,那 Pyroscope 會是您最好的選擇。

Pyroscope 架構

如果你有打算找效能分析工具平臺,Pyroscope 提供了三大優勢,讓開發者可以放心使用

  • 低 CPU 使用率,不會影響既有平臺

  • 可儲存好幾年的資料,並且可用 10 秒細顆粒度檢視資料

  • 壓縮儲存資料,減少浪費硬碟空間

  • 架構只有分 Server 和 Agent,除了 Go 語言之外,Python 跟 Ruby App 都是透過 pyroscope 指令啟動相關 app 來監控系統效能。

啟動 Pyroscope 服務

啟動方式有兩種,第一是直接用 docker 指令啟動。

$ docker run -it -p 4040:4040 pyroscope/pyroscope:latest server

另一種可以用 docker-compose 啟動。

---
services:
  pyroscope:
    image: "pyroscope/pyroscope:latest"
    ports:
      - "4040:4040"
    command:
      - "server"

安裝 Agent

在 Go 語言中使用

本篇用 Go 語言當作示例,先 import package

import "github.com/pyroscope-io/pyroscope/pkg/agent/profiler"

接著在 main.go 寫入底下程式碼即可:

profiler.Start(profiler.Config{
    ApplicationName: "simple.golang.app",
    ServerAddress:   "http://pyroscope:4040",
})

其中 http://pyroscope 可以換成自定義的 hostname 即可,接著開啟上述網址就可以看到效能監控的畫面了。

在 Python 和 Ruby 語言中使用

# If using Python
$ pyroscope exec python manage.py runserver 

# If using Ruby
$ pyroscope exec rails server    

心得

這套工具相當方便,在 Go 語言雖然可以用 pprof 快速找到問題,但是難免還是需要手動的一些地方才可以查出效能瓶頸,有了這套平臺,就可以將全部 App 都進行監控,當使用者有任何問題,就可以快速透過 Pyroscope 檢視哪些程式碼出了問題。

更多關於監控系統的推薦與介紹,請參閱公眾號專欄文章(直接點選右邊的文字直達專欄處 ): 監控系統

作者:小惡魔  

原文:http://t.cn/A6c0G3dm

推薦閱讀   點選標題可跳轉

又一款超牛逼的效能調優利器 — 火焰圖

一網際網路公司被警方一鍋端了!這種崗位千萬別幹!

入職 6 個月,被裁員。。。

武大 94 年博士年薪 201 萬入職華為!學霸日程表曝光

或將取代雲端計算!下一個技術風口來了

安排幾款實用的內網穿透工具+教程

OAuth2 vs JWT,到底怎麼選?

SpringCloud Gateway 詳解

PS:因為公眾號平臺更改了推送規則,如果不想錯過內容,記得讀完點一下 在看 ,加個 星標 ,這樣每次新文章推送 才會第一時間出現在你的訂閱列表 裡。

隨手在看、轉發是最大的支援!