Composer Scripts 可在部署时自动预热缓存,提升 PHP 应用性能。通过在 composer.json 中定义 post-install-cmd 等钩子,如 Laravel 中执行 config:cache、route:cache 等命令,结合环境判断与 CI/CD 流程,实现生产环境缓存的自动化生成,减少首次访问延迟。

在现代 PHP 应用部署中,Composer 不仅是依赖管理 工具,还能通过其 Scripts 机制优化部署流程。合理使用 Composer Scripts 预热应用程序缓存,能显著减少首次请求的响应时间,提升用户体验。
什么是 Composer Scripts
Composer Scripts 是composer.json 中定义的钩子函数,可在特定生命周期自动执行自定义 PHP 代码或命令。常见触发时机包括:post-install-cmd、post-update-cmd 和 post-autoload-dump。这些钩子非常适合在依赖安装或更新后执行缓存生成、配置编译等操作。
利用 post-install-cmd 预生成缓存
在部署过程中,Composer 通常会在生产环境运行 composer install --no-dev。我们可以利用这个时机,在依赖安装完成后立即预热框架或应用缓存。
以 Laravel 为例,在 composer.json 中添加:
“scripts”: {“post-install-cmd”: [ “@php artisan clear-compiled”, “@php artisan config:cache”, “@php artisan route:cache”, “@php artisan view:cache” ] }
这样每次执行 composer install 后,系统会自动清除旧缓存并生成新的配置、路由 和视图缓存文件,避免首次访问时动态编译带来的延迟。
为不同环境设置条件化脚本
预热缓存应仅在生产环境启用。可通过检查 环境变量 或使用脚本类来控制执行逻辑。
创建一个简单的 PHP 脚本类:
class ScriptHandler {public static function warmUpCache($event) {if (getenv(‘APP_ENV’) !== ‘production’) {return;} $commands = [‘php artisan config:cache’, ‘php artisan route:cache’,]; foreach ($commands as $cmd) {system($cmd); } } }
然后在 composer.json中注册:
“scripts”: {“post-install-cmd”: [ “ScriptHandler::warmUpCache”], “post-update-cmd”: [“ScriptHandler::warmUpCache”] }
这种方式更灵活,便于加入日志记录或错误处理。
结合 CI/CD 流程最大化效益
在持续集成流程中,可提前运行 composer install 并生成缓存,将缓存文件打包进部署产物。这样上线时无需再次执行耗时操作。
注意确保缓存生成所用的配置与目标环境一致,避免因配置差异导致缓存失效或错误。
基本上就这些。通过合理配置 Composer Scripts,让缓存预热成为部署流程的自然一环,不复杂但容易忽略。