資料介紹
軟件簡介
Deliverer 是一個 PHP 項目調度追蹤工具,主要用于線上故障排查。
使用場景
- 如果你有一些老的 PHP (PHP5 和 PHP7)項目,對線上一個項目運行邏輯不熟悉;
- 或者你對某個方法的調用來源不清楚;
- 又或者線上有一個接口不知道是哪里異常退出了;
- 還有線上調用特別耗時,都比較適合使用 Deliverer 來解決,幫助你避免跑路。
使用方法
-
可以根據
函數名
、類名
、方法名
、路由
來過濾輸出 - 可以在查詢到指定過濾內容 n 次之后退出
- 可以根據 request id 回放細看整個完整的調用鏈
- 過濾的內容會高亮顯示
- 調用棧比較深的可以指定 -l 來隱藏深度調用的展示
原理
其實比較簡單,分兩步,第一步收集日志,第二步分析日志。
第一步
在PHP_MINIT
階段,通過zend_set_user_opcode_handler
?來設置對?ZEND_DO_UCALL
?、ZEND_DO_FCALL_BY_NAME
、ZEND_DO_FCALL
?三類?opcode
?的處理分析。
注意其中會涵蓋一些內置函數和方法的調用,我們可以通過類型進行過濾。
然后在PHP_RINIT
階段新建日志文件,寫入請求的信息
pid-ts sapi http_method http_url
請求過程中在自定義的 handler 里面打印調用棧信息
最后在PHP_RSHUTDOWN
關閉日志文件的寫入
第二步
對收集好的日志,利用bin/deliverer
進行分析和整理,這塊是 php 腳本,就不贅述了。
安裝使用
下載
$ sudo wget http://github.com/zhoumengkang/deliverer/archive/refs/tags/1.0.4.zip
$ unzip 1.0.4.zip
$ rm -f 1.0.4.zip
$ cd deliverer-1.0.4/extension
編譯
$ whereis phpize
phpize: /usr/bin/phpize /usr/share/man/man1/phpize.1.gz
# 如果前面的路徑(/usr/bin)在環境變量里,也可以簡寫為 phpize,如果不太懂,直接復制執行
$ /usr/bin/phpize
$ whereis php-config
php-config: /usr/bin/php-config /usr/share/man/man1/php-config.1.gz
$ ./configure --with-php-config=/usr/bin/php-config
$ make && sudo make install
配置 php.ini
$ php -i|grep php.ini
Configuration File (php.ini) Path => /etc
Loaded Configuration File => /etc/php.ini
# 編輯 /etc/php.ini 文件
$ sudo vim /etc/php.ini
# 文件末尾增加以下兩行
[deliverer]
extension=deliverer.so
重啟 php-fpm
sudo service php-fpm restart
使用分析工具
可以移動./bin/deliverer
到你覺得合適的目錄,假如在當前目錄
# 回到文件的解壓目錄,開啟監聽
$ cd ..
$ ./bin/deliverer -t
用一段我自己很久之前的祖傳代碼(我的博客)來跑下
$ ./bin/deliverer -t
這樣會一直監控所有的 php 進程的執行
$ ./bin/deliverer -tAction::initUser -n3 -l5
參數 | 值 | 解釋 |
---|---|---|
-t | Action::initUser | 過濾包含該調用的請求 |
-n | 3 | 統計三次然后退出 |
-l | 5 | 函數(方法)調用深度顯示,最多顯示 5 層,超出部分在末尾標出 |
$ ./bin/deliverer -v7979-1624369150991941
通過?-v
?requestId
?來詳細查看完整調用棧
$ ./bin/deliverer -tSqlExecute::getAll -n1 -l3
當要查詢方法,函數調用棧過深,不在層級查詢范圍之內,則其外層調用顯示紅色
- 大象的運動追蹤開源項目
- PHP教程:foreach使用引用注意的問題
- 人體行為識別API接口aip-php-sdk-4.15.4 3次下載
- 菠菜產品項目搭建優化工具資源下載 0次下載
- PHP學習教程分享 7次下載
- 如何使用PHP-X快速開發一個PHP擴展 8次下載
- 如何利用基于字節碼插樁實現的多線程調試工具 13次下載
- 學習PHP需要注意那幾點 8次下載
- smarty如何調用PHP常量 3次下載
- 如何使用PHP-X快速開發一個PHP擴展 9次下載
- PHP基礎知識的詳細資料總結 7次下載
- PHP多個版本的比較資料說明 0次下載
- 項目管理工具的基本功能分析 3次下載
- PHP正則表達式 0次下載
- PHP/MySQL教程 0次下載
- phpy:PHP與Python互調用庫 827次閱讀
- 通達OA漏洞檢測工具介紹 3797次閱讀
- PHP中的生成器 732次閱讀
- 如何在Ubuntu 20.04安裝PHP 8.1并將其與Nginx集成 3148次閱讀
- 聊聊PHP的web應用程序開發框架存在的漏洞有哪些 1561次閱讀
- php是什么語言編寫的 4855次閱讀
- 一文知道PHP的優點和缺點 6713次閱讀
- 為什么PHP的開發效率比java高但是java比PHP流行 1w次閱讀
- PHP與Python對比 如何選擇? 4487次閱讀
- 光線追蹤算法匯總 1.7w次閱讀
- php開發中遇到的難點有哪些_十大php開發常見問題盤點 1.8w次閱讀
- DevOps工具鏈的項目端到端應用實踐過程 7060次閱讀
- php開發環境的搭建和使用 3330次閱讀
- php實現定時器任務方法詳解 1341次閱讀
- PHP實現定時任務的幾種方法詳解 7111次閱讀
下載排行
本周
- 1山景DSP芯片AP8248A2數據手冊
- 1.06 MB | 532次下載 | 免費
- 2RK3399完整板原理圖(支持平板,盒子VR)
- 3.28 MB | 339次下載 | 免費
- 3TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 4DFM軟件使用教程
- 0.84 MB | 295次下載 | 免費
- 5元宇宙深度解析—未來的未來-風口還是泡沫
- 6.40 MB | 227次下載 | 免費
- 6迪文DGUS開發指南
- 31.67 MB | 194次下載 | 免費
- 7元宇宙底層硬件系列報告
- 13.42 MB | 182次下載 | 免費
- 8FP5207XR-G1中文應用手冊
- 1.09 MB | 178次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應用800例(新編版)
- 0.00 MB | 33566次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關電源設計實例指南
- 未知 | 21549次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數字電路基礎pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅動電路設計》 溫德爾著
- 0.00 MB | 6656次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537798次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420027次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191187次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183279次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論
查看更多