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

部署自动化是现代PHP项目开发中的关键环节,而Composer脚本可以成为轻量级、可复用的自动化工具。虽然它不是替代CI/CD工具(如GitHub Actions或Jenkins)的方案,但在本地部署、简单环境同步或作为部署流程的一部分时非常实用。
在编写复杂脚本前,先明确你想自动化的步骤。常见任务包括:
目标清晰后,就可以把这些命令组织成一个串行流程。
使用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文件,便于调试和复用。例如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_HOST\n";
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脚本适合中小型项目的部署串联,关键是把逻辑拆解、保持可读性,并做好错误处理。
以上就是如何编写一个复杂的composer script来自动化部署?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号