IDC

PHP 祖传代码拯救者 Deliverer 他,来了!

作者:admin 2021-06-24 我要评论

前几日有位群友接手一段祖传代码,排查很久没有解决,准备提桶跑路,最终帮其解决,完整的过程见 https://mengkang.net/1470.html 但是最后代码的定位我有一些基...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

前几日有位群友接手一段祖传代码,排查很久没有解决,准备提桶跑路,最终帮其解决,完整的过程见 https://mengkang.net/1470.html 但是最后代码的定位我有一些基于个人经验,实际调用的链路和我预计的不一样,都是靠猜。没有看到完整的调用链路,所以我想着需要一个工具来辅助明确查询到整个完整的调用链。

所以搞了这么个工具,主要是用于一些不熟悉的项目,而且日常环境不好复现的线上场景。

deliverer 祖传代码跑路拯救者 https://github.com/zhoumengka...

如果你的项目不是那么糟糕,日常环境都 ok,那么熟悉一个项目最好的方式还是 xdebug,这个工具主要是排查线上问题。
类似的工具有 360 的 phptrace 实现原理上稍微有点不同

功能点

  • 可以根据函数名类名方法名路由来过滤输出
  • 可以在查询到指定过滤内容 n 次之后退出
  • 可以根据 request id 回放细看整个完整的调用链
  • 过滤的内容会高亮显示
  • 调用栈比较深的可以指定 -l 来隐藏深度调用的展示

原理

其实比较简单,分两步,第一步收集日志,第二步分析日志。

第一步

PHP_MINIT阶段,通过zend_set_user_opcode_handler 来设置对 ZEND_DO_UCALLZEND_DO_FCALL_BY_NAMEZEND_DO_FCALL 三类 opcode 的处理分析。

注意其中会涵盖一些内置函数和方法的调用,我们可以通过类型进行过滤。

然后在PHP_RINIT阶段新建日志文件,写入请求的信息

pid-ts sapi http_method http_url

请求过程中在自定义的 handler 里面打印调用栈信息

最后在PHP_RSHUTDOWN关闭日志文件的写入

第二步

对收集好的日志,利用bin/deliverer进行分析和整理,这块是 php 脚本,就不赘述了。

安装使用

编译

$ phpize
$ ./configure --with-php-config=/usr/local/php/bin/php-config
$ make && sudo make install

配置 php.ini

追加

[deliverer]
extension=deliverer.so

重启 php-fpm

sudo service php-fpm restart

使用分析工具

可以移动./bin/deliverer到你觉得合适的目录,假如在当前目录

$ chmod +x deliverer

用一段我自己很久之前的祖传代码(我的博客)来跑下

$ ./bin/deliverer -t

这样会一直监控所有的 php 进程的执行

0.jpg

$ ./bin/deliverer -tAction::initUser -n3 -l5

1.jpg
1.1.jpg

参数解释
-tAction::initUser过滤包含该调用的请求
-n3统计三次然后退出
-l5函数(方法)调用深度显示,最多显示 5 层,超出部分在末尾标出
$ ./bin/deliverer -v7979-1624369150991941

通过 -v requestId 来详细查看完整调用栈

2.jpg

$ ./bin/deliverer -tSqlExecute::getAll -n1 -l3

当要查询方法,函数调用栈过深,不在层级查询范围之内,则其外层调用显示红色

3.jpg


本文转自网络,版权归原作者所有,原文链接:https://segmentfault.com/a/1190000040233485

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • PHP 祖传代码拯救者 Deliverer 他,来

    PHP 祖传代码拯救者 Deliverer 他,来

  • 腾讯云IDC产品族首次亮相第七届数据中

    腾讯云IDC产品族首次亮相第七届数据中

  • SaaS公司如何通过良好的数字营销策略来

    SaaS公司如何通过良好的数字营销策略来

  • 首届神州数码云上数据开发大赛落下帷幕

    首届神州数码云上数据开发大赛落下帷幕

腾讯云代理商
海外云服务器