PHP Exec Cron Job 返回意外的 EOF

标签 php mysql exec

我正在尝试在 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: line 0: unexpected EOF while looking for matching `)'

sh: -c: line 1: syntax error: unexpected end of file

我已经检查了所有),没有发现任何不匹配的地方。 如果我注释掉 exec 命令,那么我就不会收到错误。

有人看出我做错了什么吗?

最佳答案

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

将其另存为例如备份.sh,

然后使用 crontab -e 添加新的 cron 作业(例如每天 2:15)

15 2 * * * /home/backup/backup.sh

关于PHP Exec Cron Job 返回意外的 EOF,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52346624/

相关文章:

PHP Eclipse - 为 watch 添加键绑定(bind)

javascript - 外部 PHP 数据不通过 AJAX 传递

mysql - 从表中选择每个用户的前 3 个查看图像

php - 通过 php exec() 运行 mysqldump,管道到 gzip,返回 mysqldump stderr

Javascript/jQuery Exec 结果为 Null

c - popen() 替代方案

javascript - 在 PHP 中使用定义的 jQuery 变量

php - 从 youtube channel 获取 3 最后一个视频

php - 使用 imap php 函数获取未读消息的计数

php - 我如何对数据库中的值进行计数和求和