• Главная»
  • Уроки»
  • PHP»
  • PHP: генерация резервной копии базы данных MySQL в одну строку кода

PHP: генерация резервной копии базы данных MySQL в одну строку кода

Создание резервных копий баз данных очень важная задача, которую нужно время от времени выполнять. В данной заметке вы узнаете как с помощью PHP создать дамп базы данных в одну строчку.

Для решения данной задачи можете воспользоваться командой exec().

Заметка: выбирая между shell_exec() и exec(), советуем выбрать второе. В результате нам не будет выведен весь SQL код. Данные просто запишутся в файл.

Данная команду будет:

  • выполнять команду mysqldump с набором нужных параметров,
  • записывать данные в файл.

Пример:

mysqldump --user=... --password=... --host=... DB_NAME > /path/to/output/file.sql

PHP код будет выглядеть так:

exec('mysqldump --user=... --password=... --host=... DB_NAME > /path/to/output/file.sql');

Вместо знака ... необходимо подставить имя пользователя базы данных, пароль и хост.

Помимо этого, выполнение данного файла можно подсадить на крон, поэтому имя файла можно генерировать автоматически, используя функцию даты и времени.

exec('mysqldump --user=... --password=... --host=... DB_NAME > /path/to/output/' . date('Y-m-d') . '.sql');

Данный урок подготовлен для вас командой сайта ruseller.com
Источник урока: http://stackoverflow.com/questions/6750531/using-a-php-file-to-generate-a-mysql-dump
Перевел: Станислав Протасевич
Урок создан: 28 Июля 2016
Просмотров: 8645
Правила перепечатки


5 последних уроков рубрики "PHP"

или авторизуйтесь, чтобы добавлять комментарии, оценивать уроки и сохранять их в личном кабинете
  • 1 Августа 2016 08:02
    saurys19
    Будет полезным
  • 4 Августа 2016 11:50
    dma130
    Что-то не знаю, не работает у меня вот такой код - пустой файл в итоге выдает как ни крути. Код следующий: exec('mysqldump --user=admin --password=111 --host=localhost stro > file.sql');
  • 23 Августа 2016 11:39
    rdl_team
    на многих хостинах не заработает. exec метод позволяющий оперировать командами окружения системы, а значит достаточно опасный метод для продакшена. Такие вещи перемещаются на bash скрипты, но никак не делаются на php
^ Наверх ^