Composer 在更新依赖项时挂起

Posted

技术标签:

【中文标题】Composer 在更新依赖项时挂起【英文标题】:Composer hanging while updating dependencies 【发布时间】:2015-12-10 23:50:20 【问题描述】:

我尝试使用 composer update 更新我今天正在处理的 Laravel 项目

但它挂在Updating dependencies (including require-dev)

所以我尝试了更新作曲家、转储自动加载等方法,但似乎没有任何效果。然后我以详细模式运行它:composer update -vvv

我在阅读这个 json 时注意到它挂起:

Reading path/to/Composer/repo/https---packagist.org/provider-cordoval$hamcrest-php.json from cache

我尝试在 packagist.org 上搜索 cordoval/hamcrest-php 并找不到它。这在我的composer.json中没有被列为依赖项

搜索我的供应商文件夹,我注意到我使用的mockery/mockery 包需要hamcrest/hamcrest-php,但我找不到任何引用cordoval 的内容。

知道出了什么问题以及如何修复它以便进行更新吗?

这是我的 composer.json:


    "name": "laravel/laravel",
    "description": "The Laravel Framework.",
    "keywords": ["framework", "laravel"],
    "license": "MIT",
    "require": 
        "laravel/framework": "4.2.*",
        "iron-io/iron_mq": "dev-master",
        "phpunit/phpunit": "4.2.*",
        "mockery/mockery": "dev-master",
        "xethron/migrations-generator": "dev-master",
        "mailgun/mailgun-php": "dev-master"
    ,
    "autoload": 
        "classmap": [
            "app/commands",
            "app/controllers",
            "app/models",
            "app/database/migrations",
            "app/database/seeds",
            "app/tests/TestCase.php"
        ]
    ,
    "scripts": 
        "post-install-cmd": [
            "php artisan clear-compiled",
            "php artisan optimize"
        ],
        "post-update-cmd": [
            "php artisan clear-compiled",
            "php artisan optimize"
        ],
        "post-create-project-cmd": [
            "php artisan key:generate"
        ]
    ,
    "config": 
        "preferred-install": "dist"
    ,
    "minimum-stability": "stable"

更新

我尝试从我的 composer.json 中删除一些包,包括“mockery/mockery”包。它所做的唯一改变是 Composer 会挂在不同的文件上。

Composer 就这样运行了很长时间,最终退出,报如下错误:

/path/to/ComposerSetup/bin/composer: line 18:  1356 Segmentation fault      php "$dir/composer.phar" $*

不知道该怎么办...

【问题讨论】:

你的 composer.json 是什么样的?您之前尝试过作曲家自我更新吗? 是的,我尝试了自我更新。我已经用 composer.json 更新了我的问题 您可以运行composer diagnose 来检查您是否有任何连接问题 谢谢,我不知道。 composer diagnose 给了我一些改进 composer.json 的建议,但没有任何建议可以改变问题。 【参考方案1】:

就我而言,我的 8GB ram Mac 只需要很长时间。要检查进度并验证它是否正在通过依赖项,请在详细模式下运行 composer。这是我在问题中错过的一种方法,因此值得在这里重新说明。

composer update -vvv

【讨论】:

这对我来说是解决方案,它只需要一段时间而没有给出任何关于它正在做什么的输出。因此认为在这种情况下它可能会停止。 最好的方法,因为我们会知道出了什么问题! 谢谢。这个真的很有道理。 出于某种原因,composer 与 pip 不同,它会下载整个包列表,这可能需要很长时间。【参考方案2】:

所以问题出在 php 的 xdebug 扩展上。在我的php.ini 中禁用它后,composer 运行没有任何问题。

请注意,从缓存中读取文件时实际上并没有发生挂起。这是作曲家试图解决依赖关系之后的一步。它只是从未完成该步骤并且从未打印输出。这就是为什么无论我做什么,它似乎总是卡在从缓存中读取文件。

【讨论】:

如果你不知道它为什么挂起,试试'composer diagnostic' cmd 我将网络从 wifi 切换到移动网络,可能是缓存在路由器上,奇怪但有帮助 对我来说,是 intellij 在调试端口上侦听导致问题 - 关闭 intellij 项目让 composer 正确更新。 就是这样,谢谢克里斯!【参考方案3】:

首先:检查防火墙和代理连接。如果一切正常但作曲家仍然挂起尝试清除作曲家缓存:

composer clear-cache

https://getcomposer.org/doc/03-cli.md#clear-cache

第二个选项如果这些步骤不能修复您的作曲家,那么系统可能没有足够的可用 RAM 内存(我遇到了这个问题,症状与您描述的相同)。此时你有两个选择:

a) 增加内存(虚拟机或 Docker):您的容器或 VM 需要更多可用内存。遵循本指南:https://***.com/a/44533437/3518053

b) 生成交换文件 (Linux): 尝试创建交换文件以提供更多内存: (以上命令来自composer killed while updating)

free -m
mkdir -p /var/_swap_
cd /var/_swap_
#Here, 1M * 2000 ~= 2GB of swap memory
dd if=/dev/zero of=swapfile bs=1M count=2000
mkswap swapfile
swapon swapfile
chmod 600 swapfile
echo "/var/_swap_/swapfile none swap sw 0 0" >> /etc/fstab
#cat /proc/meminfo
free -m

【讨论】:

我总是必须每隔几周回到这个答案,composer clear-cache 每次都适合我。 这很好@JaredDunham。另一种解决方法对于第一个选项不起作用的极少数情况很有用。实际上,我曾经在使用过小的虚拟机时遇到过这个问题。【参考方案4】:

有时它会卡住,因为它试图使用 HTTP 而不是 https,所以只需运行它

composer config --global repo.packagist composer https://packagist.org

【讨论】:

OMG ?️ 这些时间你在哪里?我不知道为什么它起作用了。我在没有上述命令的情况下尝试了composer require -vvv package_name,但我看到它正在使用https。但令我震惊的是,这两个命令实际上没有区别。【参考方案5】:

对我来说,问题在于 xDebug。我正在使用 IDE 的终端,调试器正在监听传入的连接(一如既往)。关闭监听(无需禁用扩展)解决了这个问题。

【讨论】:

【参考方案6】:

为我工作。 首先运行自动加载命令,然后清除缓存并运行更新。

composer dump-autoload
php artisan cache:clear
php artisan view:clear
composer update

【讨论】:

【参考方案7】:

我通过运行命令解决了它NOT IN VS CODE TERMINAL

【讨论】:

【参考方案8】:

这对我有用:

composer self-update

【讨论】:

【参考方案9】:

重启系统。

我今天遇到了同样的问题。按照建议,关闭了 xdebug,但没有帮助。验证所有文件都存在。重新启动了我的系统,它工作正常。

【讨论】:

你的意思是你优雅地重启了整个服务器?【参考方案10】:

检查您是否正在运行所需的最低 php 版本

与composer.json文件中指定的所需php版本比较

打开终端运行

php -v

在 composer.json 文件中进行交叉检查,请参见下面的示例

"require": "php": "^7.1.3",

【讨论】:

【参考方案11】:

检查 php.ini 中 [xdebug] zend_extension = "file/path" 的路径

【讨论】:

【参考方案12】:

我通过编辑 php.ini 文件解决了这个问题,以便设置 ssl 验证所需的 de cacert:

    下载文件http://curl.haxx.se/ca/cacert.pem

    编辑php.ini 设置拍子:

    [openssl]
    ; The location of a Certificate Authority (CA) file on the local filesystem
    ; to use when verifying the identity of SSL/TLS peers. Most users should
    ; not specify a value for this directive as PHP will attempt to use the
    ; OS-managed cert stores in its absence. If specified, this value may still
    ; be overridden on a per-stream basis via the "cafile" SSL stream context
    ; option.
    openssl.cafile=C:\web\certs\cacert.pem
    curl.cainfo=C:\web\certs\cacert.pem
    

    再试一次

【讨论】:

从瑞典黑客那里下载证书听起来不安全。 这个特殊的瑞典黑客是 cURL 的创建者。如果我们不能相信他,我们就不能相信互联网上的任何东西:P @IsakBerglind TIL cURL 只是在窃取我的信用卡信息以在 Valorant 上购买皮肤。【参考方案13】:

我在另一篇文章中发现了这一点,我发现执行以下操作很有效。这似乎是作曲家包缓存中的缓存/下载问题。

composer update -vvv

然后执行以下操作: 添加或编辑您的作曲家文件以进行这些设置。

"repositories": [
    
         "type": "composer", 
         "url": "https://packagist.org"
    ,
     "packagist": false 
]

【讨论】:

【参考方案14】:

就我个人而言,我使用free 发现我的系统有 0kb 的交换存储空间。使用https://linuxize.com/post/create-a-linux-swap-file/ 创建一个 1GB 的交换文件立即解决了这个问题。

【讨论】:

请不要重复已有的答案

以上是关于Composer 在更新依赖项时挂起的主要内容,如果未能解决你的问题,请参考以下文章

Composer 在 4.2 上挂起“通过 SAT 解决依赖关系”

Composer:如何在不更新旧依赖项的情况下安装另一个依赖项?

为啥 Composer 中的依赖项更新如此缓慢?

使用composer安装laravel包而不更新依赖项[重复]

更新 phpMyAdmin 时出现问题:Composer 依赖项

Composer:删除一个包,清理依赖,不要更新其他包