当我尝试运行Yii-serve时,它什么也不做.(fsockopen():无法连接)


Yii serve do nothing when I try to run it. (fsockopen(): unable to connect)

我试图开始使用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将不会启动。