PHP性能测试利器-Xdebug和phpstorm

xiaocainiao0 2019-06-21

Xdebug是一个开放源代码的PHP程序调试器(即一个Debug工具),可以用来跟踪,调试和分析PHP程序的运行状况。以下为Windows+Phpstorm+Xampp+Xdebug安装示例,MAC安装请参考集成开发和断点调试环境的配置Mac+PhpStorm+XAMPP+Xdebug

一、下载Xdebug

在下载xdebu之前,我们需要先看下我们的php版本,找到与之对应的Xdebug版本下载即可,我这里的PHP版本为V5.6.15,所以,Xdebug的版本也必须是V5.6版本。 重要的事情再说一遍:php版本和xdebug版本一定要相对应哦!!!Xdebug官网下载

查看php版本

echo phpinfo();

PHP性能测试利器-Xdebug和phpstorm

下载XdebugV5.6:

PHP性能测试利器-Xdebug和phpstorm

二、安装Xdebug

1、php.ini的配置

将下载大的扩展文件php_xdebug-2.5.0-5.6-vc11-x86_64.dll放置到php的ext扩展目录下,这个是我的扩展路径:D:xamppsphpextphp_xdebug-2.5.0-5.6-vc11-x86_64.dll,然后在php.ini中添加下面的一段扩展代码,然后保存。

[xdebug]

;指定Xdebug扩展文件的绝对路径 
zend_extension=”D:\xampps\php\ext\php_xdebug-2.5.0-5.6-vc11-x86_64.dll”
;启用性能检测分析 
xdebug.remote_enable = On
;启用代码自动跟踪  
xdebug.auto_trace=on  
;允许收集传递给函数的参数变量  
xdebug.collect_params=on  
;允许收集函数调用的返回值  
xdebug.collect_return=on  
;指定堆栈跟踪文件的存放目录  
xdebug.trace_output_dir="D:/debug"  
;指定性能分析文件的存放目录  
xdebug.profiler_output_dir="D:/debug"  

xdebug.remote_handler = dbgp
xdebug.remote_host= localhost

xdebug.remote_port = 9000

xdebug.idekey = PHPSTORM

PHP性能测试利器-Xdebug和phpstorm

说明::在上述配置内容中,zend_extension用于指定Xdebug扩展模块的文件路径(由于Xdebug是基于Zend引擎的扩展,因此必须使用zend_extension配置指令,而不是extension。zend_extension指令的配置路径必须是绝对路径)。remote_handler 、remote_host、remote_port 这些都有默认值,但还是建议设置下,至少知道要设置这些参数~

2、重启Apache

重启Apache,然后查看phpinfo(),是否已经安装Xdebug扩展成功

如果加载扩展失败,请看失败日志:
错误信息存在apache的logs文件中,error.log,查看方法如图

PHP性能测试利器-Xdebug和phpstorm

查了下原因,是因为apache为32位,php为x86即32位,而自己装了一个64位的Xdebug,所以,安装扩展失败了,这里需要找一个32位的Xdebug,并且php编译版本为V11的Xdebug:

PHP性能测试利器-Xdebug和phpstorm

三、出现的问题

安装好Xdebug后,进行断点调试又出现这样的幺蛾子:

Waiting for incoming connection with ide key '15222'

PHP性能测试利器-Xdebug和phpstorm

四、Homestead 安装Xdebug扩展

1.编译安装Xdebug

在经历了很长一段时间后,Xdebug从2.4.0版本开始,支持调试PHP 7代码,接下来,我们采用源码编译的方式进行安装。

首先,我们执行 vagrant ssh 登录到Homestead虚拟机;

其次,下载并解压Xdebug源代码:

wget http://xdebug.org/files/xdebug-2.4.0rc1.tgz
tar xvzf xdebug-2.4.0rc1.tgz

接下来,进入解压缩的目录,使用phpize7.0生成配置文件、configure、make、make install:

cd xdebug-2.4.0RC1
sudo phpize7.0
sudo ./configure --enable-xdebug
sudo make
sudo make install

PHP性能测试利器-Xdebug和phpstorm

然后创建 xdebug.ini 配置文件

mkdir -p /usr/local/php/xdebug
sudo cp /usr/local/xdebug-2.4.0RC1/modules/xdebug.so /usr/local/php/xdebug/xdebug.so
sudo vim xdebug.ini

xdebug.ini

zend_extension="/usr/local/php/xdebug/xdebug.so"
xdebug.remote_enable = 1
xdebug.remote_connect_back = 1
xdebug.remote_port = 9000
xdebug.max_nesting_level = 500
sudo mkdir /etc/php/mods-available
vagrant@homestead:/usr/local/xdebug-2.4.0RC1$ sudo cp xdebug.ini /etc/php/mods-available

接下来,在当前PHP 7 CLI和FPM的conf.d目录创建对应的符号链接:

sudo ln -snf /etc/php/mods-available/xdebug.ini /etc/php/7.0/cli/conf.d/20-xdebug.ini
sudo ln -snf /etc/php/mods-available/xdebug.ini /etc/php/7.0/fpm/conf.d/20-xdebug.ini

最后,我们重启php7.0-fpm,让新的配置生效:

sudo service php7.0-fpm restart

我们有很多方式来确认Xdebug已经正常工作了:

在Terminal执行 php -m ,在输出结果最后的[Zend Modules]部分,可以看到有Xdebug
执行php -i |grep xdebug,在输出的结果中,可以看到有xdebug support => enabled;

PHP性能测试利器-Xdebug和phpstorm

哈哈,我们看到Xdebug已经安装成功了

在导航上 Run->edit Configurations... 进入以下界面

PHP性能测试利器-Xdebug和phpstorm

相关文章:
phpstorm配置Xdebug进行调试PHP教程
上手并过渡到PHP7(1)——基于Homestead的PHP7和XDdebug环境
本地xdebug调试搭建 Laravel+homestead+phpstorm

相关推荐