PHP message PHP Fatal error require() Failed opening required ‘mcloudwwwcmcp-apivendorcomposer..myclabsdeep-copysrcDeepCopydeep_copy.php’ 的分析解决
1、查看 Nginx 的错误日志:PHP message: PHP Fatal error: require(): Failed opening required ‘/mcloud/www/cmcp-api/vendor/composer/../myclabs/deep-copy/src/DeepCopy/deep_copy.php’。如图1
2、查看 Gitlab 上的文件,发现目录:/vendor/composer/../myclabs/deep-copy 为空目录。如图2
3、删除 \vendor\myclabs\deep-copy\.git 目录。如图3
4、选择相应的文件,添加。如图4
5、提交。如图5
6、全部 – 提交 – 推送。如图6
7、查看 Gitlab 上的文件,发现目录:/vendor/composer/../myclabs/deep-copy 下已经存在相应的文件。如图7
8、构建镜像时报错:Step 4/7 : COPY code /mcloud/www/cmcp-api。Error processing tar file(exit status 1): open /vendor/myclabs/deep-copy/fixtures/f005/Foo.php: no such file or directory。如图8
9、查看 Gitlab 上的文件,发现文件:/vendor/myclabs/deep-copy/fixtures/f005/Foo.php 是存在的。如图9
10、再次构建,构建成功。如图10
11、后续还存在类似的问题。如下:
12、在目录 /vendor 中搜索:.git,发现存在数十个 .git。最终决定删除 /vendor,然后 composer install,重新安装,再删除每个目录中的 .git。重新提交推送。如图11
PHP message: PHP Fatal error: require(): Failed opening required '/mcloud/www/cmcp-api/vendor/composer/../paragonie/random_compat/lib/random.php' PHP message: PHP Fatal error: require(): Failed opening required '/mcloud/www/cmcp-api/vendor/composer/../guzzlehttp/promises/src/functions_include.php'
13、查看 Nginx 的错误日志,未再报错。符合预期。
14、参考我应该提交 vendor 目录中的依赖包吗?:https://docs.phpcomposer.com/faqs/should-i-commit-the-dependencies-in-my-vendor-directory.html 。我是采用的第 3 种方案。实际上感觉采用第 4 种方案,工作量会相对更小一些。如图12
近期评论