laravel/homestead + phpstorm + xdebug 遇到的坑

安装Homestead vagrant box
Homestead是一个由Laravel官方维护的Vagrant "box"。它基于Ubuntu 14.04,把一个LNMP环境、PHP开发常用的软件包和PHP模块“打包”在了一起,是我们部署PHP开发环境最“爽”的方式之一。作为在PHP社区最受欢迎的Framework之一,Laravel当然不会错过PHP 7版本的Homestead。接下来,我们就基于Homestead,构建一个单独用于测试PHP 7的Vagrant box。
开始前,需要安装两个软件:
Virtualbox: 开发环境将会部署和运行在一个Virutalbox虚拟机里;

Vagrant: 用来管理和启动Homestead的工具;

先下载并安装上它们,安装之后,我们需要把Homestead box下载到本地。打开系统的Terminal,运行下面的命令:
vagrant box add laravel/homestead-7

laravel/homestead + phpstorm + xdebug 遇到的坑_第1张图片
201512191450537423397248.png

之后选1,再之后,就是安静的等待homestead下载完成了。
注意:如果使用这种方式安装失败,可以先 下载对应的box文件,加入下载到了/home/virtualbox.box,然后运行命令即可,关于vagrant的使用方法可以参考 使用Vagrant打造跨平台开发环境这篇文章
vagrant box add laravel/homestead-7 /home/virtualbox.box
完成之后,我们使用:
vagrant box list
来查看安装在本地的vagrant box。
201512191450537931275187.png
201512191450537931275187.png

安装Homestead部署脚本
执行下面的命令,clone homestead部署项目到本地:
git clone -b php-7 https://github.com/laravel/homestead.git Homestead7
之后,进入Homestead7目录,执行初始化脚本:
cd Homestead7 bash init.sh
完成后,在~/.homestead目录下,就会有一个Homestead.yaml的文件。今后,我们所有的LNMP项目配置,都统一在这个文件中进行。

201512191450538069367065.png
201512191450538069367065.png

LNMP项目设置
在启动homestead之前,我们要先进行一些设置。首先,在你喜欢的地方新建一个目录php7,用来存放我们编写的PHP 7脚本。
mkdir php7
接下来,我们打开~/.homestead/Homestead.yaml,把刚才新建的代码目录,“添加”到homestead,变成一个站点。

laravel/homestead + phpstorm + xdebug 遇到的坑_第2张图片
201512191450538254312385.png

在Homestead.yaml里,我们需要修改上图中红框标记的两个地方:
folders:把Host上的源代码目录同步到virtualbox虚拟机里面的目录;

sites: map指定站点的servername;to指定HTTP root

至于其他部分,我们暂时就不需要修改了,保存文件后,退出编辑器。
Vagrant up
一切都配置完了,我们在之前的新建的php7目录添加一个测试脚本demo.php:

之后,进入Homestead7目录,执行vagrant up命令,启动homestead-7 box
成功启动之后,我们之前添加的demo.php就会被自动同步到我们在folders中配置的目录,并且homestead会自动添加我们在sites中定义站点的nginx配置文件。
接下来,我们在/etc/hosts中添加一条解析记录:
192.168.10.10 php7.app
打开浏览器,访问http://php7.app/demo.php,如果你可以看到标志性的php info页面,恭喜你,homestead已经正常工作了。

laravel/homestead + phpstorm + xdebug 遇到的坑_第3张图片
201512191450538433168158.png

编译安装Xdebug
成功部署PHP 7后,接下来我们要解决代码调试的问题,对于稍微复杂一些的项目,使用var_dump()打印变量调试非常不方便,并且不利于我们动态理解PHP代码的执行过程。而这,就是Xdebug要解决的问题。
在经历了很长一段时间后,Xdebug从2.4.0版本开始,支持调试PHP 7代码,接下来,我们采用源码编译的方式进行安装。
首先,我们在Homestead7目录,执行vagrant ssh登录到Homestead虚拟机;
其次,下载并解压Xdebug源代码:
wget https://xdebug.org/files/xdebug-2.5.4.tgz
tar xvzf xdebug-2.5.4.tgz
接下来,进入解压缩的目录,
cd xdebug-2.5.4
使用
sudo phpize7.1生成配置文件、
sudo ./configure –enable-xdebug

报错

bash:command configure not find

解决方法

find / -name php-config

image.png

重新输入命令

sudo ./configure –enable-xdebug –with-php-config=/usr/bin/php-config(具体根据返回的路劲决定)
sudo make
sudo make install
成功编译安装后,Xdebug会显示编译完成的.so文件目录,我们要记录下这个目录,

如我的目录是

image.png

让当前的PHP环境支持Xdebug调试。
启用Xdebug
首先在 /etc/php/7.1/mods-available目录里创建一个Xdebug配置文件 xdebug.ini,注意把zend_extension的目录替换成你自己的.so目录:
zend_extension="/usr/lib/php/20160303/xdebug.so"
xdebug.remote_enable = 1
xdebug.remote_connect_back = 1
xdebug.remote_port = 9000
xdebug.max_nesting_level = 500
接下来,在当前PHP 7 CLI和FPM的conf.d目录创建对应的符号链接:
sudo ln -snf /etc/php/7.1/mods-available/xdebug.ini /etc/php/7.1/cli/conf.d/20-xdebug.ini
sudo ln -snf /etc/php/7.1/mods-available/xdebug.ini /etc/php/7.0/fpm/conf.d/20-xdebug.ini
最后,我们重启 php7.1-fpm,让新的配置生效:
sudo service php7.0-fpm restart
我们有很多方式来确认Xdebug已经正常工作了:
在Terminal执行 php -m,在输出结果最后的[Zend Modules]部分,可以看到有Xdebug;

laravel/homestead + phpstorm + xdebug 遇到的坑_第4张图片
image.png

执行php -i |grep xdebug,在输出的结果中,可以看到有xdebug support => enabled;

image.png

访问我们之前的http://php7.app/demo.php,在Zend Engine图片的旁边,可以找到Xdebug标志;

image.png

综合参考资料
主要参考资料
http://www.cnblogs.com/xp796/p/6444106.html
https://xdebug.org/wizard.php
http://codecloud.net/9275.html
http://blog.csdn.net/YangWangNaTiaoLu/article/details/53012430
其实如果你用的是laravel/homestead,其本身已经安装好了xdebug 按照这个连接配置这个配置足够,记得修改php安装路径.本人也是试着配置了一遍才发现。
http://blog.csdn.net/colorapp/article/details/48089095
http://www.cnblogs.com/chunguang/p/5538405.html

你可能感兴趣的:(laravel/homestead + phpstorm + xdebug 遇到的坑)