php exec cron job返回意外的eof

zvokhttg  于 2021-06-21  发布在  Mysql
关注(0)|答案(1)|浏览(314)

我试图在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 命令,然后我没有得到错误。
有人看到我做错了什么吗?

7y4bm7vi

7y4bm7vi1#

为什么不用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

相关问题