Composer check-platform-reqs –no-dev 仅检查生产环境要求【部署】

7次阅读

composer check-platform-reqs –no-dev 检查 composer.json 中 require 声明的 php 版本、扩展及版本是否满足,忽略 require-dev,专用于部署前环境预检,避免运行时 class not found 等问题。

Composer check-platform-reqs –no-dev 仅检查生产环境要求【部署】

composer check-platform-reqs –no-dev 检查什么

它只检查 require(非 require-dev)中声明的 PHP 扩展、PHP 版本、扩展版本等是否满足,忽略所有开发依赖的平台约束。部署时用这个命令,能快速确认当前服务器环境是否跑得起来生产代码。

常见错误现象:本地 composer install 成功,但上线后报 Class not foundCall to undefined function mb_strlen() —— 很可能就是 mbstring 没装,而它只在 require 里(比如被 symfony/polyfill-mbstring 间接依赖),--no-dev 才会暴露这个问题。

  • --no-dev 不影响已安装的包,只控制「校验范围」
  • 它不读取 composer.lock,纯看 composer.jsonrequire 和平台配置(如 config.platform.php
  • 若项目用了 config.platform 模拟低版本环境,check-platform-reqs 会按该模拟值校验,不是真实服务器 PHP 版本

为什么不能只用 composer install –no-dev 来代替

composer install --no-dev 会跳过 require-dev 包的安装,但不会主动报错告诉你「ext-redis 缺失」—— 它只在安装扩展相关包时失败;而 check-platform-reqs 是专门做平台层预检的,失败即中断,适合 CI/CD 流水线卡点。

  • install --no-dev 可能因网络、权限、包冲突等失败,掩盖真正的平台缺失问题
  • check-platform-reqs 输出简洁,每行一个未满足项,例如:ext-gd is missingphp (>=8.1) is required, but 8.0.30 is installed
  • 某些扩展(如 ext-sodium)在 PHP 7.2+ 是内置的,但旧系统可能被编译掉,check-platform-reqs 能直接揪出

CI/CD 中怎么安全集成这个命令

把它放在部署前的「环境校验」阶段,而不是和 composer install 合并在一步里。一旦失败,立刻终止流程,避免部分安装后状态混乱。

  • 推荐写成独立脚本步骤:composer check-platform-reqs --no-dev || exit 1
  • 如果服务器 PHP 版本由容器或 paas 控制(如 Heroku、laravel Vapor),仍需运行——它们可能默认禁用某些扩展
  • 注意:某些共享主机禁用 dl() 或限制 extension_dircheck-platform-reqs 无法检测这类运行时限制,只能靠后续 php -m | grep redis 辅助验证

容易被忽略的 config.platform 干扰

如果 composer.json 里写了 "config": {"platform": {"php": "7.4.33"}}check-platform-reqs 会假装当前 PHP 是 7.4.33,即使你实际用的是 PHP 8.2 —— 这会导致「明明扩展已装却报错」或「该报错却没报」。

  • 部署脚本中应显式清除 platform 配置:composer check-platform-reqs --no-dev --no-plugins --no-cache
  • --no-plugins 防止第三方插件修改平台判断逻辑(如 hirak/prestissimo 旧版有干扰)
  • 最稳妥做法:在部署目标环境上,用 php -vphp -m 手动核对关键扩展,再跑 check-platform-reqs

实际部署时,这个命令本身很快,但它的价值在于把「环境不兼容」问题从运行时报错提前到构建阶段。很多人跳过它,结果线上 500 错误才去翻日志查缺哪个扩展——这时候已经晚了。

text=ZqhQzanResources