资料介绍
软件简介
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次下载
- PHP正则表达式 0次下载
- 高性能PHP应用开发 2次下载
- PHP/MySQL教程 0次下载
- phpy:PHP与Python互调用库 1.9k次阅读
- 通达OA漏洞检测工具介绍 5.2k次阅读
- PHP中的生成器 1.5k次阅读
- 如何在Ubuntu 20.04安装PHP 8.1并将其与Nginx集成 4.5k次阅读
- 聊聊PHP的web应用程序开发框架存在的漏洞有哪些 2.8k次阅读
- php是什么语言编写的 5.5k次阅读
- 一文知道PHP的优点和缺点 7.6k次阅读
- 为什么PHP的开发效率比java高但是java比PHP流行 1.1w次阅读
- PHP与Python对比 如何选择? 4.7k次阅读
- 光线追踪算法汇总 1.8w次阅读
- php开发中遇到的难点有哪些_十大php开发常见问题盘点 1.9w次阅读
- DevOps工具链的项目端到端应用实践过程 7.9k次阅读
- php开发环境的搭建和使用 3.9k次阅读
- php实现定时器任务方法详解 1.6k次阅读
- PHP实现定时任务的几种方法详解 7.3k次阅读
下载排行
本周
- 1矽力杰 Silergy SY7215A 同步升压调节器 规格书 Datasheet 佰祥电子
- 1.12 MB | 5次下载 | 免费
- 2HT81696H 内置升压的30W立体声D类音频功放数据手册
- 1.21 MB | 1次下载 | 免费
- 3HTA6863 3W超低噪声超低功耗单声道D类音频功率放大器数据手册
- 0.87 MB | 次下载 | 免费
- 4南芯 Southchip SC8802C 充电控制器 规格书 Datasheet 佰祥电子
- 88.16 KB | 次下载 | 免费
- 5矽力杰 Silergy SY7065 同步升压转换器 规格书 Datasheet 佰祥电子
- 910.67 KB | 次下载 | 免费
- 6矽力杰 Silergy SY7066 同步升压转换器 规格书 Datasheet 佰祥电子
- 989.14 KB | 次下载 | 免费
- 7WD6208A产品规格书
- 631.24 KB | 次下载 | 免费
- 8NB685 26 V,12 A,低静态电流,大电流 同步降压变换器数据手册
- 1.64 MB | 次下载 | 2 积分
本月
- 1EMC PCB设计总结
- 0.33 MB | 12次下载 | 免费
- 2PD取电芯片 ECP5702规格书
- 0.88 MB | 5次下载 | 免费
- 3矽力杰 Silergy SY7215A 同步升压调节器 规格书 Datasheet 佰祥电子
- 1.12 MB | 5次下载 | 免费
- 4氮化镓GaN FET/GaN HEMT 功率驱动电路选型表
- 0.10 MB | 3次下载 | 免费
- 5PD取电芯片,可取5/9/12/15/20V电压ECP5702数据手册
- 0.88 MB | 3次下载 | 免费
- 6SY50655 用于高输入电压应用的伪固定频率SSR反激式稳压器英文资料
- 1.01 MB | 3次下载 | 免费
- 7怎么为半导体测试仪选择精密放大器
- 0.65 MB | 2次下载 | 免费
- 8SY52341 次级侧同步整流英文手册
- 0.94 MB | 2次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935137次下载 | 10 积分
- 2开源硬件-PMP21529.1-4 开关降压/升压双向直流/直流转换器 PCB layout 设计
- 1.48MB | 420064次下载 | 10 积分
- 3Altium DXP2002下载入口
- 未知 | 233095次下载 | 10 积分
- 4电路仿真软件multisim 10.0免费下载
- 340992 | 191469次下载 | 10 积分
- 5十天学会AVR单片机与C语言视频教程 下载
- 158M | 183360次下载 | 10 积分
- 6labview8.5下载
- 未知 | 81606次下载 | 10 积分
- 7Keil工具MDK-Arm免费下载
- 0.02 MB | 73832次下载 | 10 积分
- 8LabVIEW 8.6下载
- 未知 | 65991次下载 | 10 积分
电子发烧友App





创作
发文章
发帖
提问
发资料
发视频




上传资料赚积分
评论