rsync是单向增量同步最稳方案,需加--delete清理旧文件、排除敏感配置、用-avz参数,首次同步先--dry-run验证,并同步后清OPcache和Composer autoload。
本地开发环境和线上代码不一致,90% 的问题出在手动复制漏文件、覆盖错配置、忽略 .gitignore 规则。rsync 是唯一能兼顾速度、可控性和安全性的方案,比 scp -r 或拖拽更可靠。
--delete 才能清理线上已删但本地残留的旧文件(否则越积越多)--exclude='wp-config.php' --exclude='.env' --exclude='storage/logs/'
-avz 参数:保留权限/时间戳(-a)、显示过程(-v)、压缩传输(-z)--dry-run 先看会删什么、传什么,避免误操作rsync -avz --delete \ --exclude='.git/' \ --exclude='.env' \ --exclude='storage/logs/' \ --exclude='vendor/' \ ./user@prod-server:/var/www/myapp/
.env 文件数据库密码、API 密钥、缓存主机这些一旦同步过去,本地就可能连上生产库或触发真实支付回调。不是“同步代码”,而是“同步结构 + 隔离配置”。
.env 永远不进 Git,本地也绝不覆盖它.env.example 统一字段名和注释,开发者复制后手动填本地值.env 时,可加判断跳
$_ENV['DB_HOST'] !== 'localhost' ?: die('Refuse prod config');
你加的 dd()、var_dump()、exit; 或临时绕过登录的 Auth::loginUsingId(1),很容易被忘掉并推到线上。
.git/hooks/pre-commit 里加检查:git diff --cached | grep -q "dd(" && echo "ERROR: dd() found" >&2 && exit 1
php -l 扫描语法错误,避免带 parse error 的文件被同步functions.php 开头加:if ( defined('WP_DEBUG') && WP_DEBUG ) { error_log('Local debug mode'); },上线时自动失效PHP 7.4+ 默认启用 OPcache,改完代码不重启 PHP-FPM 或不重置缓存,线上看到的还是旧逻辑。Composer 的 autoload_classmap.php 同样不会自动更新。
sudo systemctl reload php8.1-fpm(根据实际版本调整)curl -X GET http://localhost/clear-opcache.php(该脚本需含 opcache_reset() 且限制内网访问)composer dump-autoload --optimize,尤其当新增了类或修改了命名空间wp cache flush 不等于 OPcache 清理,两者都要做/ 导致 include 错目录?”
来电咨询