使用vagrant和homestead-7配置php7开发环境和Xdebug

博主推荐:yii2实战式教程是一套幽默风趣的高质量教程,从 yii2基础入门 到 yii2高级进阶,正在火热持续更新中,让你不错过yii2的每一个技术干货。

安装Homestead vagrant box

接下来,我们就基于Homestead,构建一个单独用于测试PHP 7的Vagrant box。

开始前,需要安装两个软件:

Virtualbox: 开发环境将会部署和运行在一个Virutalbox虚拟机里;

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

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

vagrant box add laravel/homestead-7

之后选1,再之后,就是安静的等待homestead下载完成了。

注意:如果使用这种方式安装失败,可以先下载对应的box文件,加入下载到了/home/virtualbox.box,然后运行命令即可,关于vagrant的使用方法可以参考使用Vagrant打造跨平台开发环境这篇文章

vagrant box add laravel/homestead-7 /home/virtualbox.box

完成之后,我们使用:vagrant box list (来查看安装在本地的vagrant box)

1acec7b014-vagrant-list.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项目配置,都统一在这个文件中进行。

01443c5a08-homestread.png

LNMP项目设置

在启动homestead之前,我们要先进行一些设置。首先,在你喜欢的地方新建一个目录php7,用来存放我们编写的PHP 7脚本。

mkdir php7

接下来,我们打开~/.homestead/Homestead.yaml,把刚才新建的代码目录,“添加”到homestead,变成一个站点。

41eec89d54-siteandfolder.png

在Homestead.yaml里,我们需要修改上图中红框标记的两个地方:

folders:把Host上的源代码目录同步到virtualbox虚拟机里面的目录; sites: map指定站点的servername;to指定HTTP root;

至于其他部分,我们暂时就不需要修改了,保存文件后,退出编辑器

Vagrant up

一切都配置完了,我们在之前的新建的php7目录添加一个测试脚本demo.php:

<?php phpinfo(); ?>

之后,进入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已经正常工作了。9c9dcec9f9-php7.png

安装xdebug

成功部署PHP 7后,接下来我们要解决代码调试的问题,对于稍微复杂一些的项目,使用var_dump()打印变量调试非常不方便,并且不利于我们动态理解PHP代码的执行过程。而这,就是Xdebug要解决的问题。

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

首先,我们在Homestead7目录,执行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
phpize7.0
configure --enable-xdebug
make
sudo make install

成功编译安装后,Xdebug会显示编译完成的.so文件目录,我们要记录下这个目录,让当前的PHP环境支持Xdebug调试。

7d8a920155-xdebug.png

启用Xdebug

首先在/etc/php/mods-available目录里创建一个Xdebug配置文件xdebug.ini,注意把zend_extension的目录替换成你自己的.so目录:

zend_extension="/usr/lib/php/20151012/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/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;
  • 访问我们之前的http://php7.app/demo.php,在Zend Engine图片的旁边,可以找到Xdebug标志;

01ca01aa02-vilidxdebug.png

配置 phpstorm 的debug

1. run->debug…

c16829df8e-install-xdebug1.png

2. 选择。Edit Configurations….

2b160144b3-install-xdebug2.png

3. 添加 php web Application

a9f295013e-install-xdebug3.png

4. 配置一个server

8749b6be65-install-xdebug4.png

5. 设置host地址, 下面具体说明怎么用homstead 快速创建vhost , Absolute path on the server这块为 你homestead里面文件的目录 (例如 /home/vagrant/Code/xxx)xxx为你项目的文件名

d636d17cfe-install-xdebug5.png

配置完后 Apply 应用,

基本的配置就完成了, 代码中打断点, 测试debug是否配置成功!

Vagrant 比较常用的命令

39e797e88a-vagrant1.png

fbe504751c-vagrant2.png

91bb492fd4-vagrant3.png

1306e35e33-vagrant4.png


  • vagrant up 开启虚拟机(进入你clone的homestead目录下运行)
  • vagrant ssh 虚拟机的SSH连接(进入你clone的homestead目录下运行)
  • vagrant halt 关闭虚拟机 (进入你clone的homestead目录下运行)

使用serve创建vhost

serve www.manks.top ~/Code/ advanced/backend/www

5db9f0c5cc-vagratel.png

这样我们的vhost就配置好了,最后一步就是在本地hosts文件中添加

192.168.10.10 www.manks.top

感觉本篇文章不错,对你有收获?

¥ 我要小额赞助,鼓励作者写出更好的教程
作者 小杰
本文版权归作者,欢迎转载,但未经作者同意必须保留 此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。