即時效能分析工具 Pyroscope
原文來自『即時效能分析工具 Pyroscope』
當網站上線後,流量增加或短暫功能故障,都會造成使用者體驗相當不好,而這時該怎麼快速找到效能的瓶頸呢?通常 CPU 衝到 100% 時,有時候也蠻難複製及找出關鍵問題點。本篇會介紹一套工具叫 pyroscope,讓開發者可以快速找到效能瓶頸的程式碼。之前也寫了相關的效能瓶頸文章,可以參考看看『Go 語言用 pprof 找出程式碼效能瓶頸』或『善用 Go 語言效能測試工具來提升執行效率』,上述兩篇都是針對 Go 語言的效能分析文章,而 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"
在 Go 裡面安裝 agent
本篇用 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 即可,接著開啟上述網址就可以看到效能監控的畫面了
透過畫面可以快速找到是 SQL 或哪個函式執行很久
心得
這套工具相當方便,在 Go 語言雖然可以用 pprof 快速找到問題,但是難免還是需要手動的一些地方才可以查出效能瓶頸,有了這套平臺,就可以將全部 App 都進行監控,當使用者有任何問題,就可以快速透過 Pyroscope 檢視看哪邊程式碼出了問題。
- 加微信實戰群請加微信(註明:實戰群):gocnio
相關文章
- 微服務效能分析|Pyroscope 在 Rainbond 上的實踐分享微服務ROSAI
- 效能分析工具 - pprof
- android效能分析工具systraceAndroid
- CPU效能分析工具原理
- SAP OData效能分析工具
- 效能分析工具簡介
- Android 效能分析工具之TraceViewAndroidView
- 記憶體效能分析工具記憶體
- Java 效能分析 5 大工具Java
- Linux 效能分析工具彙總Linux
- perf效能分析工具使用分享
- 全鏈路效能壓測工具分析和總結-實時更新
- Redis效能分析和運維工具Redis運維
- linux 效能分析工具dstat之一Linux
- PHP 效能追蹤及分析工具(XHPROF)PHP
- MySQL-09.效能分析工具的使用MySql
- 《MySQL 進階篇》十四:效能分析工具MySql
- golang 效能調優分析工具 pprof(下)Golang
- golang 效能調優分析工具 pprof (上)Golang
- MiniProfiler效能分析工具— .Net Core中用法
- valgrind和Kcachegrind效能分析工具詳解
- Linux效能分析工具與圖形化方法Linux
- Unity效能分析(一)流程與工具的使用Unity
- mysql 資料庫效能分析工具簡介MySql資料庫
- JVM效能調優,記憶體分析工具JVM記憶體
- Chrome執行時效能瓶頸分析Chrome
- JProfiler 14 for Mac(專業的Java效能分析工具)MacJava
- 效能測試之JVM的故障分析工具VisualVMJVMLVM
- 深入理解JVM:效能分析與監控工具JVM
- jmeter分析效能報告時的誤區JMeter
- 【融雲分析】 IM 即時通訊之鏈路保活
- 即時通訊
- 超牛逼的一款開源即時效能監控系統!
- 系統級效能分析工具perf的介紹與使用
- 效能測試之資料庫監控分析工具PMM資料庫
- AbsInt — 確保程式碼安全的靜態效能分析工具
- 效能工具之linux常見日誌統計分析命令Linux
- 怎麼實現微服務的實時效能分析?微服務