推薦一款開(kāi)源即時(shí)性能分析工具 Pyroscope
當(dāng)網(wǎng)站上線后,流量增加或短暫功能故障,都會(huì)造成使用者體驗(yàn)相當(dāng)不好,而這時(shí)該怎么快速找到性能的瓶頸呢?通常 CPU 達(dá)到 100% 時(shí),有時(shí)候也很難復(fù)制及找出關(guān)鍵問(wèn)題點(diǎn)。
本篇文章,我們會(huì)介紹一套工具叫 Pyroscope,讓開(kāi)發(fā)者可以快速找到性能瓶頸的代碼。Pyroscope 目前可以支持 Python, Ruby 或 Go 的環(huán)境。本文筆者會(huì)針對(duì) Go 環(huán)境做介紹。
什么是 Pyroscope?
Pyroscope 是一套開(kāi)源的性能即時(shí)監(jiān)控平臺(tái),簡(jiǎn)單的 Server 及 Agent 架構(gòu),讓開(kāi)發(fā)者可以輕松監(jiān)控代碼性能,不管你要找 10 秒或幾分鐘內(nèi)的性能數(shù)據(jù),都可以快速的即時(shí)呈現(xiàn),開(kāi)發(fā)者也不用在意裝了此監(jiān)控會(huì)造成任何性能上的負(fù)擔(dān)。Pyroscope 背后的儲(chǔ)存采用 Badger 這套 Key-Value 數(shù)據(jù)庫(kù),性能上是非常好的。目前只支持 3 種語(yǔ)言 (Python, Ruby 及 Go) 未來(lái)會(huì)預(yù)計(jì)支持 NodeJS。假設(shè)您還沒(méi)引入任何性能分析工具或平臺(tái),那 Pyroscope 會(huì)是您最好的選擇。
Pyroscope 架構(gòu)
如果你有打算找性能分析工具平臺(tái),Pyroscope 提供了三大優(yōu)勢(shì),讓開(kāi)發(fā)者可以放心使用
- 低 CPU 使用率,不會(huì)影響既有平臺(tái)
- 可儲(chǔ)存好幾年的資料,并且可用 10 秒細(xì)顆粒度查看資料
- 壓縮儲(chǔ)存資料,減少浪費(fèi)硬盤(pán)空間
- 架構(gòu)只有分 Server 和 Agent,除了 Go 語(yǔ)言之外,Python 跟 Ruby App 都是透過(guò) pyroscope 指令啟動(dòng)相關(guān) app 來(lái)監(jiān)控系統(tǒng)效能。
Pyroscope 架構(gòu)圖
啟動(dòng) Pyroscope 服務(wù)
啟動(dòng)方式有兩種,第一是直接用 docker 指令啟動(dòng)。
- $ docker run -it -p 4040:4040 pyroscope/pyroscope:latest server
另一種可以用 docker-compose 啟動(dòng)。
- ---
- services:
- pyroscope:
- image: "pyroscope/pyroscope:latest"
- ports:
- - "4040:4040"
- command:
- - "server"
安裝 Agent
在 Go 語(yǔ)言中使用
本篇用 Go 語(yǔ)言當(dāng)作示例,先 import package
- import "github.com/pyroscope-io/pyroscope/pkg/agent/profiler"
接著在 main.go 寫(xiě)入底下代碼即可:
- profiler.Start(profiler.Config{
- ApplicationName: "simple.golang.app",
- ServerAddress: "http://pyroscope:4040",
- })
其中 http://pyroscope 可以換成自定義的 hostname 即可,接著打開(kāi)上述網(wǎng)址就可以看到性能監(jiān)控的畫(huà)面了。
通過(guò)畫(huà)面,我們可以快速找到是 SQL 或哪個(gè)函式執(zhí)行時(shí)間長(zhǎng)。
在 Python 和 Ruby 語(yǔ)言中使用
- # If using Python
- $ pyroscope exec python manage.py runserver
- # If using Ruby
- $ pyroscope exec rails server
心得
這套工具相當(dāng)方便,在 Go 語(yǔ)言雖然可以用 pprof 快速找到問(wèn)題,但是難免還是需要手動(dòng)的一些地方才可以查出性能瓶頸,有了這套平臺(tái),就可以將全部 App 都進(jìn)行監(jiān)控,當(dāng)使用者有任何問(wèn)題,就可以快速透過(guò) Pyroscope 查看哪些代碼出了問(wèn)題。