資料介紹
軟件簡介
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
當要查詢方法,函數調用棧過深,不在層級查詢范圍之內,則其外層調用顯示紅色
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
- 大象的运动追踪开源项目0次下载
- PHP教程:foreach使用引用注意的问题9次下载
- 人体行为识别API接口aip-php-sdk-4.15.43次下载
- 菠菜产品项目搭建优化工具资源下载0次下载
- PHP学习教程分享7次下载
- 如何使用PHP-X快速开发一个PHP扩展8次下载
- 如何利用基于字节码插桩实现的多线程调试工具13次下载
- 学习PHP需要注意那几点8次下载
- smarty如何调用PHP常量3次下载
- 如何使用PHP-X快速开发一个PHP扩展9次下载
- PHP基础知识的详细资料总结7次下载
- PHP多个版本的比较资料说明0次下载
- PHP正则表达式0次下载
- 高性能PHP应用开发2次下载
- PHP/MySQL教程0次下载
- 一个树莓派,是如何同时实现飞机追踪、气象监测、家居控制?377次阅读
- FreeRTOS任务调度器的三种调度算法讲解(下)4378次阅读
- phpy:PHP与Python互调用库1454次阅读
- 通达OA漏洞检测工具介绍4701次阅读
- PHP中的生成器1142次阅读
- 如何在Ubuntu 20.04安装PHP 8.1并将其与Nginx集成4000次阅读
- 聊聊PHP的web应用程序开发框架存在的漏洞有哪些2417次阅读
- php是什么语言编写的5281次阅读
- 一文知道PHP的优点和缺点7358次阅读
- 为什么PHP的开发效率比java高但是java比PHP流行10695次阅读
- php开发中遇到的难点有哪些_十大php开发常见问题盘点18500次阅读
- DevOps工具链的项目端到端应用实践过程7632次阅读
- php开发环境的搭建和使用3735次阅读
- php实现定时器任务方法详解1582次阅读
- PHP实现定时任务的几种方法详解7254次阅读
下載排行
本周
- 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次下載 | 免費
評論