为什么 PHP Composer 这么慢?

Why is PHP Composer so slow?

为什么 PHP Composer 这么慢,而我所做的只是初始化一个零依赖项的项目?这是我 运行:

的命令
composer init

<逐步完成 composer.json 创建,定义 0 个零依赖项>

composer install

等3分钟(不夸张)。

作曲家所要做的就是拉入自动加载器并创建 /vendor,为什么要花这么长时间?就此而言,为什么不在 composer init 上执行该步骤?

是否有配置选项可用于在 init 时引入缓存的自动加载程序和供应商?

这里也一样。使用 "composer install --profile -vvv" 获取更多详细信息。就我而言,下载几个 JSON 文件需要很长时间。它们被缓存在我的服务器上,但它们仍然会在每次 Composer update/install 调用时下载。

... 30 分钟后...

看起来有些性能问题@packagist.org。现在 Composer 安装在 2 秒内运行!下载的 JSON 个文件已正确缓存。

因为 Composer 是由 file_get_contents() 实现的。没有 TCP 优化,没有 Keep-Alive,没有多路复用等

我创建了一个 Composer 插件来并行下载包:https://packagist.org/packages/hirak/prestissimo

$ composer global require hirak/prestissimo

请试一试。在我的环境中,composer install 变得快 10 倍。

此外,禁用 Xdebug。即使 运行 像 composer --version.

这样简单的命令,Xdebug 也会导致 Composer 花费几分钟时间
  1. 确保您拥有最新版本的 Composer。
  2. 通过添加 -vvv 以详细模式安装,例如 composer global require "squizlabs/php_codesniffer=*" -vvv
  3. 如果你能找出 Composer 在哪里面临缓慢,例如我的下载包时卡住了 5 分钟。在 50 Mbit/s 连接上下载一个 20 kB 的文件需要超过 5 分钟。这是因为它使用 HTTP 而不是 HTTPS 从 packagist 下载包。对配置进行这些更改解决了我的问题: composer config --global repo.packagist composer https://packagist.org

如果前面的任何答案都不起作用,请检查您的防火墙是否允许端口 9418 上的 TCP_OUT。

我的防火墙安全性太强了。这导致 Composer 花费了很长时间,我从未收到任何超时或端口被阻塞的指示。

我 运行 遇到了这个问题,由于我的机器上没有安装 Xdebug,所以这让我陷入了困境。原来是 IPv6 寻址模式失败。所以为了测试我 运行

curl --ipv4 'https://packagist.org/packages.json'
curl --ipv6 'https://packagist.org/packages.json'

IPv4 通过,但 IPv6 失败。最后,您应该找出为什么您的网络堆栈不支持它,但就我而言,我决定只优先考虑 IPv4 流量,直到我能解决这个问题。在 CentOS 我 created/modified 文件 /etc/gai.conf 并输入以下内容:

label       ::1/128        0
label       ::/0           1
label       2002::/16      2
label       ::/96          3
label       ::ffff:0:0/96  4
precedence  ::1/128        50
precedence  ::/0           40
precedence  2002::/16      30
precedence  ::/96          20
precedence  ::ffff:0:0/96  100

在 Ubuntu 上,您还可以编辑该文件并取消注释行

precedence ::ffff:0:0/96  100

Source on Rackspace Community Hub

在 Ubuntu Xenial 16.04 VPS 上,您需要执行以下操作:

sudo sh -c "echo 'precedence ::ffff:0:0/96 100' >> /etc/gai.conf"
composer global require hirak/prestissimo

它将 IPv4 配置为优先于 IPv6。

https://serverfault.com/questions/93717/setting-ipv4-as-preferred-protocol-over-ipv6

就我而言,我的作曲家版本 运行 宁可回溯。 更新作曲家版本后,问题消失了。

更新作曲家版本运行

composer self-update

然后需要 composer 包就大功告成了。

composer require "<package-name>"

编辑: 结论:这里没有列出任何解决方案,或者一般来说似乎是无懈可击的。 最终有帮助的通常是逐步使用 composer,使用 composer requirecomposer remove 命令一次只需要或删除一个包,还涉及添加任何“非依赖特定”设置,任何库都可以 added/removed 为了 updating/refreshing composer.json 锁缓存配置。

将我的经验与来自此处和相关链接的答案相结合。

这次我尝试了这个问题中提到的每一个解决方案。然而,它仍然对我没有帮助,尽管我 tried/noticed 安装任何其他单个库都相当快,所以我继续一个一个地研究库,这可能会导致瓶颈。

1) YES 并且我定位为密码, "codeception/codeception": "2.4.0",

单独使用将近 200 秒,尽管 运行将其与其他库一起使用有时似乎 运行将近 12 分钟。此外,作曲家在启动 20 秒后输出时似乎没有实时反映 运行 0.35s 等等。

[374.9MiB/173.14s]     39/45:   https://codeload.github.com/sebastianbergmann/php-text-template/legacy.zip/31f8b717e51d9a2afca6c9f046f5d69fc27c8686
[374.9MiB/173.16s]     40/45:   https://codeload.github.com/sebastianbergmann/diff/legacy.zip/720fcc7e9b5cf384ea68d9d930d480907a0c1a29
[374.9MiB/173.17s]     41/45:   https://codeload.github.com/sebastianbergmann/exporter/legacy.zip/68609e1261d215ea5b21b7987539cbfbe156ec3e
[374.9MiB/173.19s]     42/45:   https://codeload.github.com/sebastianbergmann/phpunit-mock-objects/legacy.zip/f9756fd4f43f014cb2dca98deeaaa8ce5500a36e
[374.9MiB/173.20s]     43/45:   https://codeload.github.com/sebastianbergmann/recursion-context/legacy.zip/5b0cd723502bac3b006cbf3dbf7a1e3fcefe4fa8
[374.9MiB/173.23s]     44/45:   https://codeload.github.com/sebastianbergmann/php-code-coverage/legacy.zip/4cab20a326d14de7575a8e235c70d879b569a57a
[374.9MiB/173.24s]     45/45:   https://codeload.github.com/doctrine/instantiator/legacy.zip/ae466f726242e637cebdd526a7d991b9433bacf1
[374.9MiB/173.24s]     Finished: success: 45, skipped: 0, failure: 0, total: 45
[374.8MiB/173.25s] Analyzed 6622 packages to resolve dependencies
[374.8MiB/173.25s] Analyzed 435842 rules to resolve dependencies
[374.8MiB/173.25s] Package operations: 54 installs, 0 updates, 0 removals
[374.8MiB/173.26s] Installs: sebastian/recursion-context:3.0.0, sebastian/exporter:3.1.2, doctrine/instantiator:1.3.0, phpunit/php-text-template:1.2.1, phpunit/phpunit-mock-objects:6.1.2, codeception/stub:1.0.4, sebastian/diff:3.0.2, sebastian/comparator:3.0.2, theseer/tokenizer:1.1.3, sebastian/version:2.0.1, sebastian/environment:3.1.0, sebastian/code-unit-reverse-lookup:1.0.1, phpunit/php-token-stream:3.1.1, phpunit/php-file-iterator:1.4.5, phpunit/php-code-coverage:6.0.5, sebastian/object-reflector:1.1.1, sebastian/object-enumerator:3.0.3, sebastian/global-state:2.0.0, phpunit/php-timer:2.1.2, symfony/polyfill-ctype:v1.17.0, webmozart/assert:1.8.0, phpdocumentor/reflection-common:2.1.0, phpdocumentor/type-resolver:1.1.0, phpdocumentor/reflection-docblock:5.1.0, phpspec/prophecy:v1.10.3, myclabs/deep-copy:1.9.5, sebastian/resource-operations:1.0.0, phar-io/version:1.0.1, phar-io/manifest:1.0.1, phpunit/phpunit:7.1.5, codeception/phpunit-wrapper:7.6.1, symfony/yaml:v4.4.8, behat/gherkin:v4.6.2, symfony/polyfill-mbstring:v1.17.0, symfony/dom-crawler:v4.4.8, symfony/css-selector:v4.4.8, symfony/browser-kit:v4.4.8, symfony/event-dispatcher-contracts:v1.1.7, psr/container:1.0.0, symfony/event-dispatcher:v4.4.8, symfony/service-contracts:v2.0.1, symfony/polyfill-php73:v1.17.0, symfony/console:v4.4.8, symfony/finder:v4.4.8, ralouphie/getallheaders:3.0.3, psr/http-message:1.0.1, guzzlehttp/psr7:1.6.1, guzzlehttp/promises:v1.3.1, symfony/polyfill-php72:v1.17.0, symfony/polyfill-intl-idn:v1.17.0, guzzlehttp/guzzle:6.5.3, symfony/process:v4.4.8, facebook/webdriver:1.7.1, codeception/codeception:2.4.0
[374.8MiB/173.28s]   - Installing sebastian/recursion-context (3.0.0): [374.9MiB/173.28s] Loading from cache[374.9MiB/173.28s]
[374.9MiB/173.28s]  Extracting archive[374.9MiB/173.51s]   - Installing sebastian/exporter (3.1.2): [374.9MiB/173.52s] Loading from cache[374.9MiB/173.52s]
[374.9MiB/173.52s]  Extracting archive[374.9MiB/173.75s]   - Installing doctrine/instantiator (1.3.0): [374.9MiB/173.76s] Loading from cache[374.9MiB/173.76s]
[374.9MiB/173.76s]  Extracting archive[374.9MiB/174.00s]   - Installing phpunit/php-text-template (1.2.1): [374.9MiB/174.00s] Loading from cache[374.9MiB/174.00s]
[374.9MiB/174.00s]  Extracting archive[374.9MiB/174.23s]   - Installing phpunit/phpunit-mock-objects (6.1.2): [374.9MiB/174.23s] Loading from cache[374.9MiB/174.23s]
[374.9MiB/174.23s]  Extracting archive[374.9MiB/174.55s]   - Installing codeception/stub (1.0.4): [374.9MiB/174.56s] Loading from cache[374.9MiB/174.56s]
[374.9MiB/174.56s]  Extracting archive[374.9MiB/174.80s]   - Installing sebastian/diff (3.0.2): [374.9MiB/174.80s] Loading from cache[374.9MiB/174.80s]
[374.9MiB/174.80s]  Extracting archive[374.9MiB/175.07s]   - Installing sebastian/comparator (3.0.2): [374.9MiB/175.07s] Loading from cache[374.9MiB/175.07s]
[374.9MiB/175.07s]  Extracting archive[374.9MiB/175.33s]   - Installing theseer/tokenizer (1.1.3): [374.9MiB/175.33s] Loading from cache[374.9MiB/175.33s]

前运行

 Problem 1
    - Installation request for codeception/codeception 2.4.0 -> satisfiable by codeception/codeception[2.4.0].
    - Conclusion: remove symfony/finder v5.0.8
    - Conclusion: don't install symfony/finder v5.0.8
    - codeception/codeception 2.4.0 requires symfony/finder >=2.7 <5.0 -> satisfiable by symfony/finder[v2.7.0, v2.7.1, v2.7.10, v2.7.11, v2.7.12, v2.7.13, v2.7.14, v2.7.15, v2.7.16, v2.7.17, v2.7.18, v2.7.19, v2.7.2, v2.7.20, v2.7.21, v2.7.22, v2.7.23, v2.7.24, v2.7.25, v2.7.26, v2.7.27, v2.7.28, v2.7.29, v2.7.3, v2.7.30, v2.7.31, v2.7.32, v2.7.33, v2.7.34, v2.7.35, v2.7.36, v2.7.37, v2.7.38, v2.7.39, v2.7.4, v2.7.40, v2.7.41, v2.7.42, v2.7.43, v2.7.44, v2.7.45, v2.7.46, v2.7.47, v2.7.48, v2.7.49, v2.7.5, v2.7.50, v2.7.51, v2.7.6, v2.7.7, v2.7.8, v2.7.9, v2.8.0, v2.8.1, v2.8.10, v2.8.11, v2.8.12, v2.8.13, v2.8.14, v2.8.15, v2.8.16, v2.8.17, v2.8.18, v2.8.19, v2.8.2, v2.8.20, v2.8.21, v2.8.22, v2.8.23, v2.8.24, v2.8.25, v2.8.26, v2.8.27, v2.8.28, v2.8.29, v2.8.3, v2.8.30, v2.8.31, v2.8.32, v2.8.33, v2.8.34, v2.8.35, v2.8.36, v2.8.37, v2.8.38, v2.8.39, v2.8.4, v2.8.40, v2.8.41, v2.8.42, v2.8.43, v2.8.44, v2.8.45, v2.8.46, v2.8.47, v2.8.48, v2.8.49, v2.8.5, v2.8.50, v2.8.52, v2.8.6, v2.8.7, v2.8.8, v2.8.9, v3.0.0, v3.0.1, v3.0.2, v3.0.3, v3.0.4, v3.0.5, v3.0.6, v3.0.7, v3.0.8, v3.0.9, v3.1.0, v3.1.1, v3.1.10, v3.1.2, v3.1.3, v3.1.4, v3.1.5, v3.1.6, v3.1.7, v3.1.8, v3.1.9, v3.2.0, v3.2.1, v3.2.10, v3.2.11, v3.2.12, v3.2.13, v3.2.14, v3.2.2, v3.2.3, v3.2.4, v3.2.5, v3.2.6, v3.2.7, v3.2.8, v3.2.9, v3.3.0, v3.3.1, v3.3.10, v3.3.11, v3.3.12, v3.3.13, v3.3.14, v3.3.15, v3.3.16, v3.3.17, v3.3.18, v3.3.2, v3.3.3, v3.3.4, v3.3.5, v3.3.6, v3.3.7, v3.3.8, v3.3.9, v3.4.0, v3.4.1, v3.4.10, v3.4.11, v3.4.12, v3.4.13, v3.4.14, v3.4.15, v3.4.16, v3.4.17, v3.4.18, v3.4.19, v3.4.2, v3.4.20, v3.4.21, v3.4.22, v3.4.23, v3.4.24, v3.4.25, v3.4.26, v3.4.27, v3.4.28, v3.4.29, v3.4.3, v3.4.30, v3.4.31, v3.4.32, v3.4.33, v3.4.34, v3.4.35, v3.4.36, v3.4.37, v3.4.38, v3.4.39, v3.4.4, v3.4.40, v3.4.5, v3.4.6, v3.4.7, v3.4.8, v3.4.9, v4.0.0, v4.0.1, v4.0.10, v4.0.11, v4.0.12, v4.0.13, v4.0.14, v4.0.15, v4.0.2, v4.0.3, v4.0.4, v4.0.5, v4.0.6, v4.0.7, v4.0.8, v4.0.9, v4.1.0, v4.1.1, v4.1.10, v4.1.11, v4.1.12, v4.1.2, v4.1.3, v4.1.4, v4.1.5, v4.1.6, v4.1.7, v4.1.8, v4.1.9, v4.2.0, v4.2.1, v4.2.10, v4.2.11, v4.2.12, v4.2.2, v4.2.3, v4.2.4, v4.2.5, v4.2.6, v4.2.7, v4.2.8, v4.2.9, v4.3.0, v4.3.1, v4.3.10, v4.3.11, v4.3.2, v4.3.3, v4.3.4, v4.3.5, v4.3.6, v4.3.7, v4.3.8, v4.3.9, v4.4.0, v4.4.1, v4.4.2, v4.4.3, v4.4.4, v4.4.5, v4.4.6, v4.4.7, v4.4.8].
    - Can only install one of: symfony/finder[v2.7.0, v5.0.8].
    - Can only install one of: symfony/finder[v2.7.1, v5.0.8].
    - Can only install one of: symfony/finder[v2.7.10, v5.0.8].
    - Can only install one of: symfony/finder[v2.7.11, v5.0.8].

2) 是 顺便说一句,我提到的 prestissimo 已经应用了,它似乎有所帮助,因为在另一台速度非常快的计算机上,它的互联网速度要快得多,而且没有密码,安装需要5 倍多,518 秒,而可能由于 prestissimo 或这里的其他建议,花了 110 秒。

composer global require hirak/prestissimo

3) YES Windows 很慢,从 Windows 到 Linux 的虚拟化文件夹也是如此。 运行 在 Linux 内的共享文件夹外似乎加速了大约两倍。 虽然它可能是由于缓存。

4) 否

    "process-timeout": 1800,

是像 git checkout 这样的单个进程,即使设置为 10s 似乎也没有任何帮助,因为它已经相当大了。它可能只有在某些服务完全中断时才有帮助。

5) YES 安装时删除供应商文件夹或清空=新鲜似乎比添加到供应商文件和其他包要快得多(大约 1 分钟或更多)存在于其中

6) YES 在没有 xdebug 自己的图像的 Ubuntu18 apache2 上似乎比在 Debian10 php-fpm 上慢,即使在 Yii2-starter-kit 有 xdebug,由于某种原因大约慢了两倍,cat /etc/*-release 找出 Linux 分布

7) 否 php -ddefault_socket_timeout=1 /usr/local/bin/composer --verbose --profile install 这里提到的似乎没有帮助 Slow updating of composer dependencies, despite --prefer-dist flag 也没有提到 IP v6 v v4 协议 虽然它可能是由于缓存。

8) NO 安装 zip 似乎没有帮助,PHP 安装已经预装了 zip,它仍然抱怨直到安装为 Linux 包,但它使单个模拟中的过程从 650 秒减慢 100 秒到 750 秒。相同的环境条件。 As there is no 'unzip' command installed zip files are being unpacked using the PHP zip extension 在无缓存条件下测试 --no-cache

9) 是 删除 "minimum-stability ": "dev",

10) YES 使用 prefer-dist composer require robmorgan/phinx:@dev --prefer-dist -vvv --profile(以 require 命令为例,使用上面首先提到的部分 require 命令,而不是通过 install 命令进行完全安装,似乎是最重要的加速之一,另外还需要 @dev- 就像之前的几点一样,当 minimum-stability: dev 没有普遍应用于所有依赖项时,使用 on per case(dependency) 似乎是无害的基础)

找出答案的最佳方法是 运行 composer update/install 冗长。作曲家{install/update} -vvv。使用标志 -h 可能会在将来帮助你

由于防病毒软件,我的下载 json 文件时速度很慢。某些防病毒软件会扫描所有网络流量,并且在分析 json 文件时可能会很慢。尝试在 运行 作曲家时禁用您的 AV。

以防万一,如果您已经删除了 composer.lock 文件,然后又去了 composer install,那么下载依赖项会变得太慢。 如果是这种情况,请使用 composer update 命令,然后它可能对您或其他人有所帮助。

步骤 1

$ composer self-update

第 2 步

$ composer clear-cache

第 3 步

$ composer update

我找到了另一个可能的解决方案,问题是您的环境中缺少 cUrl 扩展程序。所以请按照以下步骤操作

  1. 首先,检查您是否有权访问

    packagist.orgping packagist.org。如果你有从服务器回复,您已准备好进行下一步。

  2. 检查 composer diagnose 是否存在 cUrl 扩展名,对我来说,我得到的这些结果表明我没有 cUrl 扩展名,因此它可能会降低下载过程中的性能

  3. 根据您环境的 php 版本安装 curl,我的是 8,所以 sudo apt-get install php8.0-curl 对我有用

  4. 安装cUrl后,请检查是否再次安装composer diagnose,我得到了这些结果,其中描述了cUrl版本。

  5. 这解决了我在安装软件包时 composer 变慢的问题。