我试图开始使用Yii2框架。正如文件中所描述的,我做了
$composer global require "fxp/composer-asset-plugin:~1.1.1"
$composer create-project --prefer-dist yiisoft/yii2-app-basic yii2-test
然后我cd yii2-test
并运行php yii serve --port=8888
我原以为它会运行服务器,但它以代码255退出。调试器说它在线上停止
$fp = @fsockopen($hostname, $port, $errno, $errstr, 3);
错误消息为
fsockopen(): unable to connect to localhost:8888 (Connection refused)
我该如何解决这个问题?
某些环境:
描述:Ubuntu 15.10
$ php -v
PHP 5.6.11-1ubuntu3.1 (cli)
Copyright (c) 1997-2015 The PHP Group
Zend Engine v2.6.0, Copyright (c) 1998-2015 Zend Technologies
with Zend OPcache v7.0.6-dev, Copyright (c) 1999-2015, by Zend Technologies
with Xdebug v2.3.3, Copyright (c) 2002-2015, by Derick Rethans
这种奇怪的行为是由xdebug设置引起的
xdebug.halt_level=E_NOTICE|E_WARNING|E_USER_WARNING|E_USER_NOTICE
为了解决我的问题,我不得不将E_WARNING
排除在外
解释
在启动yii serve
之前,命令检查另一个应用程序是否使用所选端口。这是在方法isAddressTaken
中通过尝试在此端口打开到localhost的套接字来完成的
$fp = @fsockopen($hostname, $port, $errno, $errstr, 3);
,所以每次端口为空(yii可能会使用它),fsockopen都会生成警告,而@
会抑制该警告。
结果是:如果您有xdebug,并且它使所有脚本在出现警告时停止,那么yii serve
将不会启动。