composer脚本可用于中小型php项目部署自动化,通过定义scripts将代码检查、测试、构建、同步等任务串联,结合独立PHP脚本与环境变量管理,实现清晰、可维护的本地或轻量级部署流程。

部署自动化是现代PHP项目开发中的关键环节,而Composer脚本可以成为轻量级、可复用的自动化工具。虽然它不是替代CI/CD工具(如gitHub Actions或jenkins)的方案,但在本地部署、简单环境同步或作为部署流程的一部分时非常实用。
定义composer script的目标
在编写复杂脚本前,先明确你想自动化的步骤。常见任务包括:
- 检查代码规范(例如使用PHP CS Fixer或PHPLint)
- 运行测试(PHPUnit)
- 清除缓存(symfony、laravel等框架)
- 构建前端资源(调用npm或yarn)
- 同步文件到远程服务器(rsync或scp)
- 执行数据库迁移
- 发送部署通知(如Slack webhook)
目标清晰后,就可以把这些命令组织成一个串行流程。
在composer.json中定义脚本
使用scripts字段注册自定义命令。对于复杂逻辑,建议调用外部PHP脚本而不是写长串shell命令。
{ "scripts": { "deploy:precheck": [ "@php ./scripts/deploy/precheck.php" ], "deploy:build": [ "npm run build --cwd=assets", "@php ./scripts/deploy/build.php" ], "deploy:sync": "@php ./scripts/deploy/sync.php", "deploy:migrate": "@php ./scripts/deploy/migrate.php", "deploy:notify": "@php ./scripts/deploy/notify.php", "deploy": [ "composer run deploy:precheck", "composer run deploy:build", "composer run deploy:sync", "composer run deploy:migrate", "composer run deploy:notify" ] } }
这样你就可以通过composer run deploy一键触发整个流程。
编写独立的PHP部署脚本
将每个步骤写成独立的PHP文件,便于调试和复用。例如precheck.php:
#!/usr/bin/env php <?php // scripts/deploy/precheck.php $checks = [ 'Git干净' => function() { exec('git diff --quiet HEAD'); return $? }, 'PHP语法正确' => function() { exec('find . -name "*.php" -not -path "./vendor/*" | xargs php -l', $output, $code); return $code === 0; }, '单元测试通过' => function() { exec('phpunit --stop-on-failure', $output, $code); return $code === 0; } ]; foreach ($checks as $name => $check) { echo "✅ 正在检查:$name..."; if ($check()) { echo "通过n"; } else { echo "❌ 失败n"; exit(1); } }
确保脚本有可执行权限:chmod +x scripts/deploy/*.php
处理环境配置与安全
避免在脚本中硬编码敏感信息。使用环境变量或配置文件:
// scripts/deploy/sync.php $host = $_ENV['DEPLOY_HOST'] ?? null; $key = $_ENV['DEPLOY_SSH_KEY'] ?? '/id_rsa'; if (!$host) { echo "错误:未设置 DEPLOY_HOSTn"; exit(1); } exec("rsync -avz -e 'ssh -i $key' ./public/ user@$host:/var/www/html/", $output, $code); if ($code !== 0) { echo "同步失败n"; exit(1); }
运行前导出变量:DEPLOY_HOST=prod.example.com composer run deploy
也可以使用.env文件配合dotenv库加载配置。
基本上就这些。Composer脚本适合中小型项目的部署串联,关键是把逻辑拆解、保持可读性,并做好错误处理。


