数据库备份在laravel中失败

3wabscal  于 2021-06-20  发布在  Mysql
关注(0)|答案(1)|浏览(353)

我创建了一个用于备份数据库的cronjob,在本地运行良好。以下是本地计算机的代码:

public function handle()
    {
        $date = Carbon::now()->format('d-m-Y');            
        $user = env('DB_USERNAME');
        $password = env('DB_PASSWORD');
        $database = env('DB_DATABASE');
        $command = "mysqldump --user={$user} --password={$password} {database} > {$date}.sql";
        $path = 'User Database Backup/'.Carbon::now()->format('F').' '.Carbon::now()->format('Y');
        $process = new Process($command);        
        $process->start();    

        while ($process->isRunning()) {

            $public = Storage::disk('public');
            $public->put('users/'.$path.'/'.$date.".sql", file_get_contents("{$date}.sql"));       
            unlink("{$date}.sql");      
        }       
    }

但当我在生产中的laravel应用程序中应用相同的方法时,它会创建一个sql文件,其中包含:

Usage: mysqldump [OPTIONS] database [tables]
OR     mysqldump [OPTIONS] --databases [OPTIONS] DB1 [DB2 DB3...]
OR     mysqldump [OPTIONS] --all-databases [OPTIONS]
For more options, use mysqldump --help

下面是我在生产应用程序中使用的代码。我正在将sql文件推送到s3存储。

public function handle()
    {
        $date = Carbon::now()->format('d-m-Y');            
        $user = env('DB_USERNAME');
        $password = env('DB_PASSWORD');
        $database = env('DB_DATABASE');
        $command = "mysqldump --user={$user} --password={$password} {$database} > {$date}.sql";
        $path = 'User Database Backup/'.Carbon::now()->format('F').' '.Carbon::now()->format('Y');
        $process = new Process($command);        
        $process->start();    

        while ($process->isRunning()) {

            $s3 = Storage::disk('s3');
            $s3->put('users/'.$path.'/'.$date.".sql", file_get_contents("{$date}.sql"));       
            unlink("{$date}.sql");      
        }       
    }

有人能告诉我为什么会这样吗?如何解决这个问题

yh2wf1be

yh2wf1be1#

这是我的工作,不是存储。我将检查>{$date}.sql的路径权限

相关问题