执行 Composer 任何命令无反应的解决(open_basedir 问题)

下面由composer教程栏目给大家介绍当执行 Composer 任何命令无反应时(open_basedir 问题)的解决办法,希望对需要的朋友有所帮助!

执行 Composer 任何命令无反应的解决(open_basedir 问题)

环境

CentOS 7

Nginx 1.12.0

PHP 7.1.6

问题

原本使用都正常,因需要创建个新项目,我就使用 Composer 进行创建,但是没有任何显示,相继的执行了创建其它项目也没有任何反应。添加 -vvv 选项后,结果也是没有任何变化,随后尝试执行 composer -h、composer self update 等等命令,也无任何的提示信息。

再次执行了个 Composer 相关命令后,随即执行了 echo $?,得到了 255 的结果。

尝试新安装 Composer 时,出现了 open_basedir 的相关错误提示,顿时就知道问题所在了,在这次创建新项目前,我配置了 php.ini 的 open_basedir 选项,值为项目目录和 /tmp/,Composer 的工作目录为项目目录。

随即注释了 open_basedir 并重启 PHP 后,Composer 的使用果然没有问题了。但是我还是想设置 open_basedir ,下面就是解答。

使用 Nginx

无论是外部的请求服务端解析还是终端 PHP 命令都会走 php.ini 文件,但是 Composer 的执行是系统本地的。也就是说,如果要是从 Nginx 上进行设置,本地执行 Composer 是不会受影响的。

Nginx 增加配置

fastcgi_param  PHP_ADMIN_VALUE "open_basedir=项目目录/:/tmp/";

重启 Nginx、PHP 后,终端中尝试执行 Composer 无异常了。Nginx 配置中对 open_basedir 的配置需要注意两点。

如果你的程序是框架,那么不建议写 $document_root/,因为那是 root 值,而这个值是框架的入口的目录,运行起来一定会出错的。你要是懂了,你还可以写 $document_root/,但是别忘了增加整个网站的所在目录

目录结尾记得加上 「/」,例如写「/tmp/」而不是「/tmp」,要是写「/tmp」那么「/tmp1」也是允许的范围内

我就是要用 php.ini

事情很明显,Composer 命令的执行所需要的目录不仅仅是在项目目录(也是我执行 Composer 命令的工作目录)和 tmp 目录,查找了相关资料也没有结果,最后整理了一下思路,对 php.ini 的 open_basedir 原本值中增加了 Composer 的命令所在目录和 Composer 的文件目录后,重启 PHP,Composer 正常了。

以上就是执行 Composer 任何命令无反应的解决(open_basedir 问题)的详细内容,更多请关注其它相关文章!