Laravel 5.6 - Резервное копирование базы данных mySql на S3? - PullRequest
0 голосов
/ 05 февраля 2019

Я пытаюсь сделать резервную копию всей базы данных mysql на S3 следующим образом:

<?php
    namespace App\Console\Commands;

    use Carbon\Carbon;
    use Illuminate\Console\Command;
    use Illuminate\Support\Facades\Storage;
    use Symfony\Component\Process\Process;

    class DatabaseBackup extends Command {
        /**
         * The name and signature of the console command.
         *
         * @var string
         */
        protected $signature = 'backup:database';
        /**
         * The console command description.
         *
         * @var string
         */
        protected $description = 'Take a backup of the entire DB and upload to S3.';
        /**
         * Create a new command instance.
         *
         * @return void
         */
        public function __construct()
        {
            parent::__construct();
        }
        /**
         * Execute the console command.
         *
         * @return mixed
         */
        public function handle()
        {
            $date = Carbon::now()->format('Y-m-d_h-i');
            $user = env('DB_USERNAME');
            $password = env('DB_PASSWORD');
            $database = env('DB_DATABASE');
            $command = "mysqldump --user={$user} -p{$password} {$database} > {$date}.sql";
            $process = new Process($command);
            $process->start();
            while ($process->isRunning()) {
                $s3 = Storage::disk('s3');
                $s3->put('gallery-app-db/' . $date . ".sql", file_get_contents("{$date}.sql"));
                unlink("{$date}.sql");
            }
        }
    }

Но при запуске php artisan backup:database, а затем при просмотре файла .sql корзины и локальной загрузке файла .sql,он показывает вот так вместо фактической базы данных / таблиц, находящихся в файле:

enter image description here

Любая идея, как заставить работать .sql-дамп и выполнить резервное копированиенастоящая база данных вместе со всеми ее таблицами вместо файла использования?

1 Ответ

0 голосов
/ 05 февраля 2019

Предположим, ваш пароль содержит символ, который завершает команду оболочки, например ; & | && ||

Или символ, заканчивающий аргумент командной строки, например, пробел.

Или некоторые другие специальные символы, такие как кавычки любого типа, или $ или !.

Без кавычек пароля, скорее всего, будет срезана команда.

Я предлагаю поместить ваше имя пользователя и пароль в файл опций, а затем сослаться на этот файл опций с помощью --defaults-file=...

$command = "mysqldump --defaults-file=mysql-dump.cfg {$database} > {$date}.sql";

mysql-dump.cfg должен содержать что-то вроде:

[client]
user = <your user>
password = <your password>

Было бы также неплохо избегать размещения вашего пароля в открытом виде от тех, кто может запустить ps.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...