0

0

Composer dry-run模式详解:如何在实际执行前模拟安装过程?

冰火之心

冰火之心

发布时间:2026-01-02 09:37:02

|

127人浏览过

|

来源于php中文网

原创

--dry-run 是 Composer 的安全预演命令,用于提前识别依赖冲突、版本不兼容、扩展缺失等风险,必须在拉分支、CI检查、PR评审等关键场景强制执行。

composer dry-run模式详解:如何在实际执行前模拟安装过程?

--dry-run 不会装任何包,也不会改任何文件,但它能告诉你“如果真执行,Composer 会干啥”——这是你上线前、合代码前、加依赖前最该跑的一条命令。

什么时候必须用 composer install --dry-run

不是“可选”,而是“不跑就容易翻车”的场景:

  • 刚拉完新分支,composer.jsoncomposer.lock 有变动,想确认会不会意外升级 symfony/console 到 v7(而你的 PHP 还是 8.1)
  • CI/CD 流水线里,想在 composer install 前加一道检查:如果解析出要装 ext-gd 但当前环境没启用,就直接失败
  • 团队协作中收到 PR 修改了 require-dev,你不想本地 install 后才发现 phpunitsebastian/environment 升级到了不兼容版本

composer require --dev --dry-run 的真实价值

它不只是“看看要装啥”,而是帮你拦截开发依赖引发的隐性破坏:

  • 运行 composer require --dev phpunit/phpunit --dry-run 时,输出里如果出现 will update doctrine/instantiator from 1.5.0 to 2.0.0,就得立刻查文档——v2 是 PHP 8.1+ only,而你项目还跑在 8.0 上
  • 如果看到 will remove myproject/utils,说明新包和你已有的工具类存在自动加载冲突或命名空间重叠,不是版本问题,是结构问题
  • 它不会触发 post-autoload-dump 脚本,所以即使预览时看到“会生成新的 autoload 文件”,也代表真实安装后可能因脚本失败而中断

composer update --dry-run 为什么composer show --outdated 更关键?

show --outdated 只告诉你“哪些包有新版”,而 update --dry-run 告诉你“更新后整个依赖树会变成什么样”:

arXiv Xplorer
arXiv Xplorer

ArXiv 语义搜索引擎,帮您快速轻松的查找,保存和下载arXiv文章。

下载
  • 它会模拟锁文件重写过程,显示 composer.lock 中哪些包的 content-hashplatformdist.reference 会被修改
  • 输出中若出现 downgrading myvendor/package (dev-main → v3.2.1),说明约束冲突导致 Composer 回退版本——这往往意味着你写的 ^4.0 和某个间接依赖的 ~3.0 碰上了,不干预就会丢功能
  • -v 参数(即 composer update --dry-run -v)能看到解析器决策日志,比如:Trying monolog/monolog:3.0.0 -> satisfiable by monolog/monolog[3.0.0],这对排查“为啥没装上我要的版本”极其有用

容易被忽略的细节和坑

很多人以为 --dry-run 就是“安全模式”,其实它有边界:

  • 它不校验实际网络可达性——预览成功不代表 packagist.org 没被墙,也不代表私有仓库 token 有效
  • 它跳过所有 scripts 执行,所以不会触发 post-install-cmd 里的数据库迁移检查,也不会运行 phpstan 静态分析
  • 如果你用了 path 类型仓库(如本地开发包),--dry-run 仍会尝试读取其 composer.json,但不会验证路径是否存在——路径错,预览照样过,真装时才报错
  • composer install --dry-run 默认基于现有 composer.lock,而 composer update --dry-run 忽略 lock 文件重新解析——别混用场景

真正起作用的从来不是“知道有这个参数”,而是把它塞进你的日常节奏:每次改完 composer.json,先 --dry-run;每次准备部署,CI 里加一行 composer install --dry-run 并设为失败退出码非零;每次 Review 依赖相关 PR,第一眼就看 --dry-run 输出有没有降级或平台变更。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2021

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1344

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1250

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

948

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1402

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1231

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1440

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1303

2023.11.13

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.2万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号