php phpanalysis2.0,使用phpAnalysis打造PHP应用非侵入式性能分析器
使用phpAnalysis打造PHP應(yīng)用非侵入式性能分析器,查找PHP性能瓶頸。
什么是phpAnalysis
phpAnalysis是一款輕量級非侵入式PHP應(yīng)用性能分析器,適用于開發(fā)、測試及生產(chǎn)環(huán)境部署使用,方便開發(fā)及測試工程師診斷性能問題:
通過tideways收集PHP程序單步運行過程中所有的函數(shù)調(diào)用時間及CPU內(nèi)存消耗等信息
信息永久存儲到MySQL數(shù)據(jù)庫
分析每個請求執(zhí)行的信息,幫助開發(fā)測試人員快速定位性能問題
非侵入式,不需修改項目PHP代碼
被動分析器,對性能的影響最小,同時收集足夠的信息用于診斷性能問題
當(dāng)我們發(fā)現(xiàn)生產(chǎn)環(huán)境的某個接口執(zhí)行時間特別長時應(yīng)該怎么做?
直接登錄線上機器單步調(diào)試?
打大量的log然后分析?
一般我們可以把分析流程拆分為如下幾步操作:
分析開發(fā)/測試環(huán)境下執(zhí)行是否會慢
分析預(yù)發(fā)/Mirror環(huán)境執(zhí)行是否會慢
生產(chǎn)環(huán)境分析代碼執(zhí)行慢的原因
1,2,3步驟都需要去分析代碼,看哪部分執(zhí)行時間長。如果人工一行代碼去排查,需要消耗大量的開發(fā)人員的時間并且定位難度很大,于此,phpAnalysis誕生了 :)
安裝
準(zhǔn)備
依賴的PHP擴展:tideaways, PDO, pdo_mysql, zlib
PHP版本>= 5.4.0
安裝phpAnalysis
下載源代碼
cd /home/www
git clone https://github.com/dreamans/phpAnalysis.git
cd phpAnalysis
修改配置文件
文件位置:/home/www/phpAnalysis/config/database.php
修改數(shù)據(jù)庫鏈接信息
數(shù)據(jù)庫需要自己創(chuàng)建
建表語句請見install.sql
return [
'connection' => [
'host' => '127.0.0.1', // 數(shù)據(jù)庫主機名
'port' => 3306, // 數(shù)據(jù)庫端口號
'user' => 'root', // 用戶名
'pass' => 'root', // 密碼
'db' => 'phpAnalysis', // 數(shù)據(jù)庫名
'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程序在執(zhí)行前首先調(diào)用此文件
auto_prepend_file = /home/www/phpAnalysis/agent/header.php
[tideways]
extension=tideways.so
;不需要自動加載,在程序中控制就行
tideways.auto_prepend_library=0
;頻率設(shè)置為100,在程序調(diào)用時能改
tideways.sample_rate=100
重啟php-fpm進程
如果安裝順利,此時訪問 http://localhost:8000 能看到效果
預(yù)覽
請求列表
支持按應(yīng)用實例名稱、請求時段、url模糊查詢篩選列表
請求執(zhí)行基本信息
請求攜帶的數(shù)據(jù)
調(diào)用明細
說明
項目處于開發(fā)階段,權(quán)限控制未完成且未做性能優(yōu)化,請勿在生產(chǎn)環(huán)境中部署,感謝支持!
總結(jié)
以上是生活随笔為你收集整理的php phpanalysis2.0,使用phpAnalysis打造PHP应用非侵入式性能分析器的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
                            
                        - 上一篇: php 单例模式原理,PHP单例模式de
 - 下一篇: java 文件下载漏洞,文件上传和下载漏