Vagarnt Virtual配置多YII服务Xdebug
目录
1 下载并安装Xdebug
2 配置PHPstorm,连接虚拟机PHP
3 配置Xdebug
4 建立PHP服务
5 验证服务
6 处理发现的问题
1 下载并安装Xdebug
通过命令查询是否安装了xdebug扩展
# php -v
如果版本信息中没有包含xdebug信息,则表示没有安装xdebug扩展
PHP版本信息通过apt-get安装xdebug
# sudo apt-get install xdebug
安装成功后一般会在/usr/lib/php目录下找到xdebug的扩展文件xdebug.so,如果没有就通过下面这个命令来查找
# sudo find / -name "xdebug.so"
我当时找到好几个目录,就逐个尝试,把xdebug.so填到php.ini后,再通过查看php版本来验证版本是否匹配。因为是配置cli的php.ini文件,所以不需要重启php-fpm。
多个版本的xdebug扩展文件下面是配置的命令
# sudo vim /etc/php/7.2/cli/php.ini
加入以下内容
[xdebug]
zend_extension="/usr/lib/php/20170718/xdebug.so"
xdebug.remote_enable=1
xdebug.remote_handler=dbgp
xdebug.remote_mode=req
xdebug.remote_host=192.168.10.10
xdebug.remote_port=9000
最终在20170718这个目录跟我的PHP 7.2.11版本成功匹配上,通过查看PHP版本发现xdebug版本是v2.6.1。
在完成cli的php.ini配置后,也需要在fpm的php.ini写入相应的命令,并完成php-fpm的重启。
2 配置PHPStorm,连接虚拟机PHP
完成Xdebug扩展安装后,开始连接PHPStorm和虚拟机,打开PHPStorm的设置,搜索并点击PHP,进入PHP设置区域。
php的设置界面设置PHP版本为7.2,下一步点击...符号,选择PHP的cli命令文件。初始打开一般是空的,需要点击+号,选择要连接虚拟机或本地的php命令。
选择不同端的php命令点击From Docker, Vagrant, Vm, WSL,Remote... 选项后弹出选择器,接着点击Vagrant 选项,然后第一个目录是选择Vagrantfile所在的目录,选择成功后PHPStorm会自动查找虚拟机的PHP目录,如果查找失败,就要自己选择正确的命令位置。
这里要注意的是,Homestead的Vagrant虚拟机中,会在多个PHP版本中给配置一个默认的PHP版本。配置设置版本的代码在homestead.rb文件中。
选择vagrant目录,以及远程PHP的命令目录 homestead.rb给php_cli命令设置默认的PHP版本在完成虚拟机PHP路径配置后,配置界面会实时同步PHP的版本信息,需要注意PHP的版本信息以及Xdebug版本信息是否也预期的一致,如果不一致则需要继续检查php脚本路径等。
如果版本信息一致,则继续完成Xdebug扩展文件的填写,填入Debugger Extension输入框中。而下面的配置项则可以不填。
查看PHP版本和Xdebug的版本3 配置Xdebug
在完成PHP配置后,回到PHP配置界面。
回到php配置界面选择Debug,进入DBGp Proxy界面,完成Xdebug的连接配置。其中Host是虚拟机的IP地址,IDE key和Port可以通过phpinfo信息中的Xdebug信息中获取到。
配置xdebug连接 xdebug的默认key xdebug的默认端口号完成xdebug的连接配置后,即可以验证xdebug服务是否生效。回到debug配置的主界面,检查xdebug配置是否准备就绪。无误后点击Validate进行验证。
检查Xdebug配置在验证界面中输入其中一个服务的本地web目录,输入服务的访问地址。点击Validate开始验证,当所有验证项都通过时,即表示xdebug服务成功开启。校验成功后,即可点击Start Listening按钮,打开Xdebug的监听了。
验证成功校验
4 建立PHP服务
接着进入PHP下面的server界面,为第一个PHP服务都建立一个server。目录右边的目录必须为虚拟机中的项目绝对路径。Debugger处选择为Xdebug。
设置多个PHP服务完成多个PHP服务配置后,回到PHPstorm主界面,点击右上角Edit Configurations...开启PHP应用。在开启应用界面中,需要再次点击Validate来验证Xdebug是否可用。
开启PHP应用 再次验证XdeBug是否可用 开始监听5 验证服务
打开浏览器或者API工具,打好断点,开始美妙的开发之旅,再也不用每次调试都要键入exit()来打断点了。优雅又省心。
图片来自在Homestead搭建的开发环境下使用PHPStorm Xdebug进行调试 - 程序员大本营 (pianshen.com)6 处理发现的问题
1、Xdebug的连接,DBGp Proxy配置中,IP地址为vagrant虚拟机连接的IP地址。
homestead.yaml中的IP地址2、composer无法通过PHPStorm连接虚拟机中的composer脚本,如果宿主机器不安装composer就无法通过PHPStorm来完成依赖包的更新。
3、在通过composer脚本更新依赖包的时候,gmp这个扩展无法通过apt直接进行安装,最后是下载了PHP7.2.11的源码包,在ext目录中找到gmp目录,通过phpize进行安装。在configure时需要判断 php-config的版本是不是跟php_cli脚本同一个版本。
# /usr/bin/phpize
# ./configure --with-php-config=/usr/bin/php-config
# make & make install
将生成的gmp.so扩展文件放入fpm的php.ini配置中。