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

本文的测试环境是mac,理论上来说,centos等linux系列里面,这些也都差不多。
准备工作
phptrace是数字公司出品的,其github主页是:
取得本地php-config的路径,并记录下路径/usr/bin/php-config备用。命令有2个,任选其一。
which php-configwhereis php-config 下载源码并解压
下载master分支代码,大家都会下载,下载后解压。进入解压后的extension目录。
curl -LOk https://github.com/Qihoo360/phptrace/archive/master.zip
tar zxvf master.zip
cd phptrace-master/extension

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



请替换上述脚本中的php-config的路径,具体路径可以在第一步中获得。
- 最后的截图中,我们可以看到,编译好的
so文件,所放置的路径。如果需要,请到这里查看。 - 注意:最后的
install命令,所放置的module的目录可能是个错误的目录。所以,最终您可能需要手工cp一下,修正一下扩展文件的正确位置。 - 如果你需要
cp动作的话,可能意味着:您编译得到的so文件是个和php主程序版本不匹配的文件。修改ini后,您可以通过phpinfo()查看是否成功。
编辑php.ini
ini的路径,也可以通过phpinfo()查看。找到文件后,增加如下语句即可。
[phptrace]
extension=trace.so
phptrace.enabled = 1
重启生效
重启后,phpinfo里面,可以看到trace的相关信息。如果没有什么变化,那么可能是加载失败了。

官方给出的验证办法是这样的。在命令行里面输入如下语句。然后如果看到类似的输出即可。
php -r 'for ($i = 0; $i < 20; $i++) usleep(50000);' &
phptrace -p $!
当然你还可以通过命令行验证是否生效。
php -m|grep trace
最后总结
这里面编译的过程中,可能会碰到很多问题,苏南大叔在以前的文章里面有过提及。将在下一篇文章里面再对php的扩展编译过程中,可能出现的错误,再次总结。
phptrace的相关文章,请点击这里查看: