• Главная»
  • Уроки»
  • 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
Просмотров: 8834
Правила перепечатки


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

  • Фильтрация данных с помощью zend-filter

    Когда речь идёт о безопасности веб-сайта, то фраза "фильтруйте всё, экранируйте всё" всегда будет актуальна. Сегодня поговорим о фильтрации данных.

  • Контекстное экранирование с помощью zend-escaper

    Обеспечение безопасности веб-сайта — это не только защита от SQL инъекций, но и протекция от межсайтового скриптинга (XSS), межсайтовой подделки запросов (CSRF) и от других видов атак. В частности, вам нужно очень осторожно подходить к формированию HTML, CSS и JavaScript кода.

  • Подключение Zend модулей к Expressive

    Expressive 2 поддерживает возможность подключения других ZF компонент по специальной схеме. Не всем нравится данное решение. В этой статье мы расскажем как улучшили процесс подключение нескольких модулей.

  • Совет: отправка информации в Google Analytics через API

    Предположим, что вам необходимо отправить какую-то информацию в Google Analytics из серверного скрипта. Как это сделать. Ответ в этой заметке.

  • Подборка PHP песочниц

    Подборка из нескольких видов PHP песочниц. На некоторых вы в режиме online сможете потестить свой код, но есть так же решения, которые можно внедрить на свой сайт.

или авторизуйтесь, чтобы добавлять комментарии, оценивать уроки и сохранять их в личном кабинете
  • 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
^ Наверх ^