推薦一款開源即時性能分析工具 Pyroscope
當網(wǎng)站上線后,流量增加或短暫功能故障,都會造成使用者體驗相當不好,而這時該怎么快速找到性能的瓶頸呢?通常 CPU 達到 100% 時,有時候也很難復制及找出關鍵問題點。
本篇文章,我們會介紹一套工具叫 Pyroscope,讓開發(fā)者可以快速找到性能瓶頸的代碼。Pyroscope 目前可以支持 Python, Ruby 或 Go 的環(huán)境。本文筆者會針對 Go 環(huán)境做介紹。
什么是 Pyroscope?
Pyroscope 是一套開源的性能即時監(jiān)控平臺,簡單的 Server 及 Agent 架構,讓開發(fā)者可以輕松監(jiān)控代碼性能,不管你要找 10 秒或幾分鐘內的性能數(shù)據(jù),都可以快速的即時呈現(xiàn),開發(fā)者也不用在意裝了此監(jiān)控會造成任何性能上的負擔。Pyroscope 背后的儲存采用 Badger 這套 Key-Value 數(shù)據(jù)庫,性能上是非常好的。目前只支持 3 種語言 (Python, Ruby 及 Go) 未來會預計支持 NodeJS。假設您還沒引入任何性能分析工具或平臺,那 Pyroscope 會是您最好的選擇。
Pyroscope 架構
如果你有打算找性能分析工具平臺,Pyroscope 提供了三大優(yōu)勢,讓開發(fā)者可以放心使用
- 低 CPU 使用率,不會影響既有平臺
 - 可儲存好幾年的資料,并且可用 10 秒細顆粒度查看資料
 - 壓縮儲存資料,減少浪費硬盤空間
 - 架構只有分 Server 和 Agent,除了 Go 語言之外,Python 跟 Ruby App 都是透過 pyroscope 指令啟動相關 app 來監(jiān)控系統(tǒng)效能。
 
Pyroscope 架構圖
啟動 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 即可,接著打開上述網(wǎng)址就可以看到性能監(jiān)控的畫面了。
通過畫面,我們可以快速找到是 SQL 或哪個函式執(zhí)行時間長。
在 Python 和 Ruby 語言中使用
- # If using Python
 - $ pyroscope exec python manage.py runserver
 - # If using Ruby
 - $ pyroscope exec rails server
 
心得
這套工具相當方便,在 Go 語言雖然可以用 pprof 快速找到問題,但是難免還是需要手動的一些地方才可以查出性能瓶頸,有了這套平臺,就可以將全部 App 都進行監(jiān)控,當使用者有任何問題,就可以快速透過 Pyroscope 查看哪些代碼出了問題。



















 
 
 














 
 
 
 