Бекап всех баз данных
1 |
# mysqldump -u root -p123456789 --all-databases > all_databases.sql |
Бекап конкретной базы данных
1 |
#mysqldump -u root -p123456789 joomla_on > joomla_on.sql |
Бекап конкретной базы данных с экспортом хранимых процедур и функций
1 |
#mysqldump -u root -p123456789 --routiness joomla_on > joomla_on.sql |
Бекап нескольких баз данных
1 |
#mysqldump -u root -p123456789 -B joomla_on wordpress_on > 2databases.sql |
Бекап конкретных таблиц hzesp_schemas hzesp_session из базы данных joomla_on
1 |
#mysqldump -u root -p123456789 joomla_on hzesp_schemas hzesp_session > 2tables.sql |
Резервное копирование структуры таблицы
1 |
# mysqldump -u root -p123456789 --no-data joomla_on hzesp_session > hzesp.sql |
Резервное копирование содержимого таблицы
1 |
# mysqldump -u root -p123456789 --no-create-info joomla_on hzesp_session > hzesp_data.sql |
Резервное копирование ТОЛЬКО процедур и функций
(без создания структуры и данных базы данных)
1 |
#mysqldump -u root -p123456789 --routines --no-create-info --no-data --no-create-db --skip-opt joomla > joomla.sql |
Резервное копирование базы данных с удаленного сервера в файл на локальном компьютере
1 |
#mysqldump –h hostname -u root –pXXX database > database.sql |
Восстановление базы данных из бекапа
1 |
# mysql -u root -p123456789 joomla_on < joomla.sql |
(предварительно нужно создать эту базу. Если не хочется предварительно создавать базу данных, значит нужно использовать опцию –databases при создании бекапа mysqldump —database …)
Восстановление базы на удаленном сервере из файла на локальном сервере
1 |
#mysql –h hostname -u root –pXXX database < database.sql |
Восстановление базы на удаленном сервере из бекапа созданного на локальном сервере
1 |
#mysqldump –u root –p123456789 -EKR --add-drop-database --single-transaction database | mysql –u root –pXXX -h remoteserver |
Если доступ к MySQL на удаленном сервере закрыт,то делаем через ssh-подключение
1 |
#mysqldump –u root –p123456789 -EKR --add-drop-database --single-transaction database | ssh root@hostname 'mysql –u root –pXXX' |
Удаленное создание дампа базы database через ssh c выгрузкой на локальный сервер в файл /tmp/database.sql
1 |
# ssh -p2222 root@myserver.com 'mysqldump -u root –p123456789 -EKR --single-transaction database' > /tmp/database.sql |
Удаленное создание дампа базы database через ssh и вливание этого дампа в локальную базу test
1 |
# ssh -p2222 root@myserver.com 'mysqldump -u root -123456789 -EKR --single-transaction database' | mysql -u root -p123 test |
Полезные опции mysqldump расписаны ниже
1 |
-EKR --add-drop-database --single-transaction |
Восстановление всех баз данных
1 |
# mysql -u root -p123456789 < all_databases.sql |
Восстановление таблицы(указываем в какую базу данных восстановить)
1 |
# mysql –u root –p123456789 database table < table.sql |
При создании дампа базы данных в СУБД MySQL с помощью утилиты mysqldump она по умолчанию делает таблицы недоступными на запись на все время создания дампа. Это приводит к негативным последствиям, например, в случае использования форума phpBB.
При каждом заходе на форум phpBB в MySQL обновляются некоторые данные (производятся не только операции чтения, но и операции записи). В итоге, при использовании mysqldump в режиме по умолчанию форум будет недоступен все время выполнения дампа.
Решение этой проблемы в случае использования движка хранения данных InnoDB весьма тривиально. У mysqldump есть опция
1 |
--single-transaction |
, которая добавляет SQL-выражение BEGIN перед дампом всех данных из БД, что позволяет получить дамп одной транзакцией, без блокировки таблиц.
Для MyISAM можно воспользоваться опцией
1 |
--lock-tables |
, которая блокирует таблицы с помощью READ LOCAL, что позволяет выполнять запросы INSERT в MyISAM-таблицы во время выполнения дампа.
Кроме того, при дампе больших таблиц с помощью mysqldump рекомендуется использовать опцию
1 |
--quick |
Использование клиентской утилиты mysql в интерактивном режиме()
1 |
MariaDB [(none)]> create database joomla_on; |
1 |
MariaDB [(none)]> use joomla_on; |
1 |
MariaDB [joomla_on]> source /root/joomla.sql; |
Параметры программы Mysqldump
1 |
--help, -? |
Вывод справки по опциям и используемым переменным.
1 |
--add-drop-database |
Добавляет команду, DROP DATABASE перед каждой командой CREATE DATABASE
1 |
--add-drop-table |
Добавляет команду, DROP TABLE перед каждой командой CREATE TABLE
1 |
--add-locks |
Обрамляет дамп командами LOCK TABLES и UNLOCK TABLES, для ускорения операций вставки.
1 |
--all-databases, -A |
Создает полную резервную копию всех баз данных, текущего сервера.
1 |
--allow-keywords |
Разрешить имена столбцов, совпадающие с зарезервированными ключевыми словами. К имени такого столбца, добавляется префикс таблицы.
1 |
--character-sets-dir= путь |
Директории с установленными наборами символов кодировок
1 |
--comments, -i |
Добавить в файл дампа, дополнительную информацию ( например, версию программы, версию MySQL, имя хоста ), отменяется опцией —skip-comments
1 |
--compact |
Создает более компактный дамп. Использование данного параметра, автоматически включает опции: —skip-add-drop-table, —skip-add-locks, —skip-comments, —skip-disable-keys и —skip-set-charset.
1 |
--compatible= имя |
Данная опция, пытается повысить совместимость создаваемого дампа, с базой данных другого типа или с более старой версией MySQL. Возможные значения: ansi, mysql323, mysql40, postgresql, oracle, mssql, db2, maxdb, no_key_options, no_table_options или no_field_options. Можно использовать несколько значений, разделенных запятыми.
1 |
--complete-insert, -c |
Использовать полную форму оператора INSERT, включая имена столбцов.
1 |
--compress, -C |
Использовать компрессию, при пересылке данных между клиентом и сервером, при условии, что они оба поддерживают компрессию.
1 |
--create-options |
Включать все MySQL опции при использовании оператора CREATE TABLE.
1 |
--databases, -B |
Делать дамп нескольких баз данных, перечисленных после данной опции. Без этого параметра, mysqldump, воспринимает в качестве имени базы данных, первое значение, остальные интерпретируются как имена таблиц.
1 |
--default-character-set= кодировка |
Донная опция устанавливает кодировку по-умолчанию. Если не определена, используется utf8, в ранних версиях latin1.
1 |
--delayed-insert |
Вместо оператора INSERT, использовать INSERT DELAYED.
1 |
--delete-master-logs |
Удалять бинарный лог на основном сервере репликаций после создания дампа. При использовании этой опции, автоматически включается опция —master-data.
1 |
--disable-keys, -K |
Оператор INSERT для каждой таблицы, обрамляется выражением /*!40000 ALTER TABLE tbl_name DISABLE KEYS */ и /*!40000 ALTER TABLE tbl_name ENABLE KEYS */. Данная опция ускоряет загрузку при восстановлении из дампа, для таблиц типа MyISAM, за счет того, что индексы создаются после вставки всех данных.
1 |
--dump-date |
Если включена опция —comments, добавлять дату создания дампа.
1 |
--extended-insert, -e |
Использовать многострочный синтаксис оператора INSERT. Уменьшает размер дампа и ускоряет последующую вставку данных.
1 |
--flush-logs, -F |
Переоткрыть лог файлы, перед созданием резервной копии. Старый файл будет сохранен с суффиксом -old. При использовании с опцией —all-databases ( сокращенный вариант -A), будут переоткрыты лог-файлы каждой базы данных, для которой делается дамп.
1 |
--flush-privileges |
Выполнять команду FLUSH PRIVILEGES после создания дампа базы данных.
1 |
--force, -f |
Продолжать создание резервной копии даже в случае возникновения ошибки.
1 |
--host= имя_хоста, -h имя_хоста |
Указывает хост MySQL сервера. По-умолчанию резервная копия делается для хоста localhost
1 |
--hex-blob |
Представлять бинарные данные полей BINARY, VARBINARY, BLOB и BIT в шестнадцатиричном формате ( hex ).
1 |
--ignore-table= имя_базы.имя_таблицы |
Не скидывать в дамп таблицу «имя_таблицы» из базы «имя_базы«. Опцию нужно использовать повторно, для каждой игнорируемой таблицы.
1 |
--insert-ignore |
Дописывать в оператор INSERT, опцию IGNORE.
1 |
--lock-all-tables, -x |
Блокировка всех таблиц, во всех базах, на время создания резервной копии. Данная опция автоматически отключает —single-transaction и —lock-tables.
1 |
--lock-tables, -l |
Блокировка таблиц базы данных, на время создания резервной копии. При дампе всех баз данных с этой опцией, таблицы каждой базы блокируются отдельно. Для транзакционных таблиц, типа InnoDB и BDB, предпочтительней использовать опцию —single-transaction.
1 |
--log-error= имя_файла |
Писать ошибки и предупреждения в файл «имя_файла«.
1 |
--no-autocommit |
Включает операторы INSERT для каждой таблицы, в операторы SET AUTOCOMMIT и COMMIT, для увеличения скорости выполнения большого количества запросов INSERT
1 |
--no-create-db, -n |
Данная опция подавляет вывод в дамп оператора CREATE DATABASE, при использовании опций —databases и —all-databases.
1 |
--no-create-info, -t |
Не писать оператор CREATE TABLE, для пересоздания каждой таблицы из резервной копии.
1 |
--no-data, -d |
Не скидывать в дамп содержимое таблиц. Оставляет только операторы CREATE TABLE для создания структуры.
1 |
--opt |
Групповая опция. Синоним включения опций, —add-drop-table, —add-locks, —create-options, —disable-keys, —extended-insert, —lock-tables, —quick, —set-charset. Ускоряет общий процесс создания резервной копии, включена по-умолчанию. Отключается опцией —skip-opt.
1 |
--order-by-primary |
Сортировать ряды таблиц по первичному ключу или по первому уникальному индексу, если индекс существует. Полезна в случае создания дампа таблиц MyISAM с последующей вставкой в таблицы типа InnoDB.
1 |
--password[=password], -p[password] |
Пароль пользователя, для подключения к серверу. Не забывайте, что имя должно идти сразу за опцией, без разделяющего пробела. Если указаны только сама опция, без пароля, пароль будет запрошен из командной строки.
1 |
--port= номкр_порта, -P номкр_порта |
Номер порта, для подключения к серверу по протоколу TCP/IP.
1 |
--protocol={TCP|SOCKET|PIPE|MEMORY} |
Использовать для подключения к серверу MySQL, указанный протокол.
1 |
--quick, -q |
Данная опция вынуждает Mysqldump, восстанавливать строки, по одной за раз, вместо того что-бы скидывать весь объем строк в буфер памяти и выписывать их оттуда. Очень полезна при создании резервных копий больших таблиц.
1 |
--quote-names, -Q |
Обрамлять имена баз данных, таблиц и колонок, ковычками. Включена по-умолчанию.
1 |
--replace |
Использовать оператор REPLACE вместо INSERT. Начиная с версии MySQL 5.1.3.
1 |
--result-file= имя_файла, -r имя_файла |
Вывод результатов в указанный файл. Имейте в виду, если файл с таким именем уже существует, он будет перезаписан и в случае возникновения ошибки, данные могут быть потеряны.
1 |
--routines, -R |
Записывать в дамп хранимые процедуры и функции. Для использования данной опции, необходимы права SELECT на таблицу proc, системной базы данных mysql. Дамп будет содержать операторы CREATE PROCEDURE и CREATE FUNCTION. При использовании этой опции, эти операторы не будут содержать атрибутов времени создания и модификации хранимых процедур и функций и после восстановления дампа они будут равны времени восстановления. Если вам необходимо сохранить исходные атрибуты времени, вместо использования данной опции, сделайте отдельный дамп таблицы mysql.proc, под именем пользователя, который имеет на это достаточные права. Опция появилась с версии MySQL 5.1.2.
1 |
--set-charset |
Добавляет в дамп оператор SET NAMES со значением кодировки по-умолчанию. По-умолчанию, данная опция включена, что-бы подавить, используйте —skip-set-charset.
1 |
--single-transaction |
Выполняет оператор BEGIN SQL, перед началом создания резервной копии. Опция используется только для транзакционных таблиц, типа InnoDB. Только этот тип таблиц может быть сохранен в дамп в актуальном состоянии, после выполнения BEGIN SQL, и без блокирования приложения. Например таблицы типа MyISAM или MEMORY, могут измениться в процессе создания резервной копии с использованием данной опции, в итоге, информация в дампе будет противоречивой, неактуальной. Опции —single-transaction и —lock-tables, являются взаимоисключающими.
1 |
--socket= путь_к_файлу_сокета, -S путь_к_файлу_сокета |
Использовать файл unix-сокета, для подключения к localhost.
1 |
--tables |
Имена идущие за этой опцией, считаются именами таблиц.
1 |
--triggers |
Включать в резервную копию триггеры, для каждой таблицы. Отменить действие опции можно с помощью —skip-triggers.
1 |
--user= имя_пользователя, -u имя_пользователя |
Имя пользователя для подключения к MySQL серверу.
1 |
--verbose, -v |
Вывод служебной информации о ходе выполнения программы.
1 |
--where='where_условие', -w 'where_условие' |
Скидывать в дамп информацию, выбранную по условию WHERE.
1 |
--xml, -X |
Создать дамп в формате XML
Источник:
http://petrenco.com/mysql.php?txt=46
http://www.nixp.ru/recipes/13.html