提交composer.lock并启用多级缓存,结合–prefer-dist与–no-dev策略及国内镜像,可显著加速CI/CD中的composer install过程。

在CI/CD流程中,composer install 往往是php项目构建阶段的耗时大户。优化这一步骤能显著缩短流水线执行时间,提升开发效率。关键在于减少重复下载、合理利用缓存和精简安装过程。
启用并正确配置缓存
大多数CI平台(如gitHub Actions、gitlab CI、CircleCI)支持缓存依赖目录。将 Composer 的 vendor 目录和全局包缓存目录缓存下来,可避免每次从远程拉取所有包。
- 缓存 vendor/ 目录:确保 composer.lock 文件已提交,这样 install 可复用锁定版本。
- 缓存 Composer 全局缓存(通常位于 ~/.composer/cache 或 $COMPOSER_CACHE_DIR):避免重复下载相同版本的包。
- 以 GitLab CI 为例:
cache: paths: - vendor/ - ~/.composer/cache/
使用 –prefer-dist 和 –no-dev(按环境)
根据部署环境选择合适的安装策略:
- –prefer-dist:优先从 dist(压缩包)而非源码安装,速度更快。
- 在生产或测试构建中,若无需开发依赖,添加 –no-dev,减少安装包数量。
- 示例命令:
composer install --prefer-dist --no-progress --no-scripts --no-interaction
在非本地环境中去掉 –no-scripts 可跳过 post-install-cmd 等脚本,进一步提速。
保持 composer.lock 提交并使用 –no-install
确保 composer.lock 文件始终提交到版本控制。CI 环境中,Composer 可基于 lock 文件精确安装,无需解析依赖关系。
- 如果项目依赖无变更,且缓存命中,install 过程会极快。
- 可结合 composer install –no-install 做检查(实际场景较少),重点仍是 lock 文件的维护。
使用镜像或私有仓库加速下载
在国内或网络受限环境,官方 Packagist 下载慢。可通过以下方式提速:
composer config repo.packagist composer https://mirrors.aliyun.com/composer/
- 企业项目可搭建 Satis 或 Toran proxy 私有仓库,集中管理并缓存外部包。
基本上就这些。核心是:提交 lock 文件、启用多级缓存、按需安装、使用镜像。组合起来,composer install 在 CI 中可从几十秒降至几秒。不复杂但容易忽略细节。


