使用phpAnalysis打造PHP應用非侵入式效能分析器

dreamans發表於2019-02-16

使用phpAnalysis打造PHP應用非侵入式效能分析器,查詢PHP效能瓶頸。

什麼是phpAnalysis

phpAnalysis是一款輕量級非侵入式PHP應用效能分析器,適用於開發、測試及生產環境部署使用,方便開發及測試工程師診斷效能問題:

  • 通過tideways收集PHP程式單步執行過程中所有的函式呼叫時間及CPU記憶體消耗等資訊
  • 資訊永久儲存到MySQL資料庫
  • 分析每個請求執行的資訊,幫助開發測試人員快速定位效能問題
  • 非侵入式,不需修改專案PHP程式碼
  • 被動分析器,對效能的影響最小,同時收集足夠的資訊用於診斷效能問題

當我們發現生產環境的某個介面執行時間特別長時應該怎麼做?
直接登入線上機器單步除錯?
打大量的log然後分析?

一般我們可以把分析流程拆分為如下幾步操作:

  1. 分析開發/測試環境下執行是否會慢
  2. 分析預發/Mirror環境執行是否會慢
  3. 生產環境分析程式碼執行慢的原因

1,2,3步驟都需要去分析程式碼,看哪部分執行時間長。如果人工一行程式碼去排查,需要消耗大量的開發人員的時間並且定位難度很大,於此,phpAnalysis誕生了 :)

安裝

準備

  1. 依賴的PHP擴充套件:tideaways, PDO, pdo_mysql, zlib
  2. PHP版本>= 5.4.0

安裝phpAnalysis

下載原始碼

cd /home/www
git clone https://github.com/dreamans/phpAnalysis.git
cd phpAnalysis

修改配置檔案

檔案位置:/home/www/phpAnalysis/config/database.php
修改資料庫連結資訊
資料庫需要自己建立
建表語句請見install.sql

return [

    'connection' => [

        'host' => '127.0.0.1', // 資料庫主機名

        'port' => 3306, // 資料庫埠號

        'user' => 'root', // 使用者名稱

        'pass' => 'root', // 密碼

        'db' => 'phpAnalysis', // 資料庫名

        'tb_prefix' => 'pa_',  // 表字首
    ],
];

修改Web Server配置,以Nginx為例

server {
    listen       8000;
    server_name  localhost;
    root  /home/www/phpAnalysis/public;
    index index.html;

    location ~ \.php$ {
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include        fastcgi_params;
    }
}

修改php.ini

; 告訴PHP程式在執行前首先呼叫此檔案
auto_prepend_file = /home/www/phpAnalysis/agent/header.php
[tideways]
extension=tideways.so
;不需要自動載入,在程式中控制就行
tideways.auto_prepend_library=0
;頻率設定為100,在程式呼叫時能改
tideways.sample_rate=100

重啟php-fpm程式

如果安裝順利,此時訪問 http://localhost:8000 能看到效果

預覽

  • 請求列表

支援按應用例項名稱、請求時段、url模糊查詢篩選列表
pa_list.png

  • 請求執行基本資訊

pa_detail_base.png

  • 請求攜帶的資料

pa_detail_base_infos.png

pa_detail_base_post.png

  • 呼叫明細

pa_detail_list.png

說明

專案處於開發階段,許可權控制未完成且未做效能優化,請勿在生產環境中部署,感謝支援!

對專案有任何意見建議請提issue https://github.com/dreamans/p...

相關文章