我们相信:世界是美好的,你是我也是。平行空间的世界里面,不同版本的生活也在继续...

苏南大叔在本篇文章中,将要给大家带来一款php扩展,叫phptrace。是国内的数字公司出品的,主要功效还是用于分析php程序,找函数的调用关系。当然,和断点调试一样,这些功能本来对于其他语言来说,都是标配的。但是到php这里,又变成了稀罕物件。哎.....

苏南大叔:php 函数调用追踪扩展插件 phptrace ,如何编译安装? - phptrace-install
php 函数调用追踪扩展插件 phptrace ,如何编译安装?(图11-1)

本文的测试环境是mac,理论上来说,centoslinux系列里面,这些也都差不多。

准备工作

phptrace是数字公司出品的,其github主页是:

取得本地php-config的路径,并记录下路径/usr/bin/php-config备用。命令有2个,任选其一。

which php-config
whereis php-config 

下载源码并解压

下载master分支代码,大家都会下载,下载后解压。进入解压后的extension目录。

curl -LOk https://github.com/Qihoo360/phptrace/archive/master.zip
tar zxvf master.zip 
cd phptrace-master/extension

苏南大叔:php 函数调用追踪扩展插件 phptrace ,如何编译安装? - curl
php 函数调用追踪扩展插件 phptrace ,如何编译安装?(图11-2)

苏南大叔:php 函数调用追踪扩展插件 phptrace ,如何编译安装? - ls
php 函数调用追踪扩展插件 phptrace ,如何编译安装?(图11-3)

源码编译

phpize
./configure --with-php-config=/usr/bin/php-config
make
make cli
sudo make install-all

苏南大叔:php 函数调用追踪扩展插件 phptrace ,如何编译安装? - phpize
php 函数调用追踪扩展插件 phptrace ,如何编译安装?(图11-4)

苏南大叔:php 函数调用追踪扩展插件 phptrace ,如何编译安装? - 003
php 函数调用追踪扩展插件 phptrace ,如何编译安装?(图11-5)

苏南大叔:php 函数调用追踪扩展插件 phptrace ,如何编译安装? - 004
php 函数调用追踪扩展插件 phptrace ,如何编译安装?(图11-6)

苏南大叔:php 函数调用追踪扩展插件 phptrace ,如何编译安装? - 005
php 函数调用追踪扩展插件 phptrace ,如何编译安装?(图11-7)

请替换上述脚本中的php-config的路径,具体路径可以在第一步中获得。

  • 最后的截图中,我们可以看到,编译好的so文件,所放置的路径。如果需要,请到这里查看。
  • 注意:最后的install命令,所放置的module的目录可能是个错误的目录。所以,最终您可能需要手工cp一下,修正一下扩展文件的正确位置。
  • 如果你需要cp动作的话,可能意味着:您编译得到的so文件是个和php主程序版本不匹配的文件。修改ini后,您可以通过phpinfo()查看是否成功。

编辑php.ini

ini的路径,也可以通过phpinfo()查看。找到文件后,增加如下语句即可。

[phptrace]
extension=trace.so
phptrace.enabled = 1

苏南大叔:php 函数调用追踪扩展插件 phptrace ,如何编译安装? - trace_ini
php 函数调用追踪扩展插件 phptrace ,如何编译安装?(图11-8)

重启生效

重启后,phpinfo里面,可以看到trace的相关信息。如果没有什么变化,那么可能是加载失败了。

苏南大叔:php 函数调用追踪扩展插件 phptrace ,如何编译安装? - phptrace_info
php 函数调用追踪扩展插件 phptrace ,如何编译安装?(图11-9)

官方给出的验证办法是这样的。在命令行里面输入如下语句。然后如果看到类似的输出即可。

php -r 'for ($i = 0; $i < 20; $i++) usleep(50000);' &
phptrace -p $!

苏南大叔:php 函数调用追踪扩展插件 phptrace ,如何编译安装? - ok
php 函数调用追踪扩展插件 phptrace ,如何编译安装?(图11-10)

当然你还可以通过命令行验证是否生效。

php -m|grep trace

苏南大叔:php 函数调用追踪扩展插件 phptrace ,如何编译安装? - phptrace_info_2
php 函数调用追踪扩展插件 phptrace ,如何编译安装?(图11-11)

最后总结

这里面编译的过程中,可能会碰到很多问题,苏南大叔在以前的文章里面有过提及。将在下一篇文章里面再对php的扩展编译过程中,可能出现的错误,再次总结。

phptrace的相关文章,请点击这里查看:

如果本文对您有帮助,或者节约了您的时间,欢迎打赏瓶饮料,建立下友谊关系。
本博客不欢迎:各种镜像采集行为。请尊重原创文章内容,转载请保留作者链接。

 【福利】 腾讯云最新爆款活动!1核2G云服务器首年50元!

 【源码】本文代码片段及相关软件,请点此获取更多信息

 【绝密】秘籍文章入口,仅传授于有缘之人   php    pecl