我正在尝试执行cron作业期间的php脚本,以将我的MySQL数据库转储到用于备份的文件夹中。
$DBHost = 'localhost';
$DBName = 'mydatabase';
$DBUser = 'myuser';
$DBPassword = 'mypassword';
$PATH = "/home/mysite/Backups/";
$FILE_NAME = "backup-" . date( "Y-m-d_H:i:s" ) . ".sql.gz";
exec( '/usr/local/bin/mysqldump -u ' . $DBName . ' -p' . $DBPassword . ' ' . $DBName . ' | gzip --best > ' . $PATH . $FILE_NAME );
但是我不断收到错误消息:
sh:-c:第0行:寻找匹配的“)”时出现意外的EOF
sh:-c:第1行:语法错误:文件意外结束
我已经检查了所有)
,但是找不到任何不匹配的内容。
如果我注释掉exec
命令,那么我不会得到错误。
有人看到我在做什么错吗?
答案 0 :(得分:0)
为什么不用sh编写整个代码?
#!/bin/bash
dbname="database"
dbuser="user"
dbpass="password"
path="/home/backup"
now=$(date + "%Y-%m-%d")
/usr/bin/mysqldump -u $dbuser -p$dbpass $dbname | gzip > $path/backup_$now.sql.gz
另存为backup.sh,
然后使用crontab -e添加新的cron作业(例如每天2:15)
15 2 * * * /home/backup/backup.sh