Как передать базу данных mysql
Перейти к содержимому

Как передать базу данных mysql

Перенос базы данных MySQL со старого на новый сервер

img

Перенос или миграция базы данных MySQL или MariaDB между серверами обычно занимает всего несколько простых шагов. В этой статье мы расскажем про них, и вы сможете легко перенести данные со старого Linux сервера на новый, импортировать и выполнить проверку того что все прошло без ошибок. Поехали!

MySQL Migration

Подготовка

Первым делом нужно убедиться, что и на старом, и на новом сервере установлена одинаковая версия MySQL с одинаковым дистрибутивом. Для этого в командной строке выполните:

mysql -V

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

Экспортируем базу данных MySQL в файл дампа

Внимание! Не переносите каталог data на новый сервер и не меняйте внутреннюю структуру БД.

Сначала на старом сервере остановите службу mysql или mariadb, используя команду systemctl:

# systemctl stop mariadb ИЛИ # systemctl stop mysql

Затем сделайте дамп ваших баз MySQL с помощью команды mysqldump:

# mysqldump -u [user] -p --all-databases > all_databases.sql

Если база одна, то можно использовать команду:

# mysqldump -u root -p --opt [database name] > database_name.sql
Перенос дампа MySQL на новый сервер

Теперь используйте команду scp, чтобы перенести файл дампа на новый сервер. После подключения база будет перенесена на новый сервер.

# scp all_databases.sql user@merionet.ru:~/ [Все базы] # scp database_name.sql user@merionet.ru:~/ [Одна база]
Импорт файла дампа MySQL на новый сервер

После того как файл дампа был перенесен, нужно выполнить следующую команду для импорта всех баз данных в MySQL.

# mysql -u [user] -p --all-databases < all_databases.sql [All Databases] # mysql -u [user] -p newdatabase < database_name.sql [Singe Database]
Проверка импорта

После завершения импорта вы можете проверить базы данных на обоих серверах:

# mysql -u user -p # show databases;
Перенос баз данных и пользователей MySQL на новый сервер

Если нужно переместить все свои БД MySQL, пользователей, разрешения и структуру данных старого сервера на новый, то нужно использовать команду rsync. С ее помощью скопируется весь контент из каталога данных mysql или mariadb на новый сервер.

# rsync -avz /var/lib/mysql/* user@merionet.ru:/var/lib/mysql/

Как только передача завершится, вы можете установить владельца каталога данных mysql или mariadb для пользователя и группы mysql. Для того чтобы убедиться, что что все файлы были переданы можно выполнить просмотр каталога.

# chown mysql:mysql -R /var/lib/mysql/ # ls -l /var/lib/mysql/

Готово! Мы только что очень быстро и просто выполнили миграцию всех баз со старого сервера на новый.

Перенос базы данных MySQL

Перенос базы данных (БД) преследует собой цель создания её копии с последующим развертыванием на ином сервере.

Как перенести базу данных MySQL

  1. Посредством web-приложения phpMyAdmin (для веб-хостинга и VDS).
  2. Через доступ по SSH протоколу (только для VDS).
  3. Используя программное обеспечение сторонних разработчиков.

В данной статье изложены первых два способа.

Чтобы перенести на другой хостинг базу, необходимо сначала выполнить её экспорт, т.е. создать дамп (от англ. dump — «разгрузка», «вывод»). Затем — провести процедуру импорта полученного дампа на другом сервере.

Создание дампа

Дамп представляет собой файл, содержащий текстовую информацию в виде SQL-запросов. Как правило, он сохраняется с расширением «SQL» или вообще без расширения. Его можно сформировать с помощью web-интерфейса phpMyAdmin или через панель виртуального хостинга (ISPmanager).

Как создать дамп базы данных через ISPmanager

В ISPmanager можно скачать существующую базу данных. Для этого нужно зайти в панель управления, выбрать раздел «Базы данных», выбрать нужную БД и нажать «Скачать».

Как создать дамп базы данных через phpMyAdmin

1. Заходим в панель управления ISPmanager. Переходим в раздел «Базы данных». Выбираем нужную базу и нажимаем «Web интерфейс БД». Запустится web-интерфейс управления БД — phpMyAdmin.

2. В левой панели выбрать базу данных, подлежащую экспорту, путём однократного нажатия на её названии левой кнопкой мыши.
3. Открыть вкладку «Экспорт».
4. Выбрать формат «SQL».
5. Нажать «Вперед» и сохранить файл на компьютер.

Как перенести базу данных MySQL на хостинг или сервер

В зависимости от версии phpMyAdmin в перечне настроек закладки «Экспорт» может присутствовать опция «Сохранить как файл» (или «Сохранить вывод в файл»). Соответственно, перед нажатием «ОК» следует убедиться, что эта опция включена.

Как перенести базы данных на хостинг

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

Как выгрузить дамп на хостинг через ISPmanager

В ISPmanager можно скачать существующую базу данных. Для этого нужно зайти в панель управления, в разделе «Основное» выбрать «Базы данных», выбрать нужную БД и нажать «Загрузить».

Как выгрузить дамп на хостинг через phpMyAdmin

1. Запустить web-интерфейс управления БД — phpMyAdmin.
2. Убедиться, что в левой панели отсутствует база с наименованием вновь импортируемой.
3. Открыть вкладку «Импорт».
4. Выбрать импортируемый файл БД.
5. Убедиться, что установлена необходимая кодировка (по умолчанию — UTF-8);
6. Нажать «Вперед».

Как перенести базу данных MySQL на хостинг или сервер

Как перенести базу данных на виртуальный сервер (VPS)

Процесс переноса баз данных на VPS аналогичен импорту БД на хостинг. Выполнить загрузку дампа базы данных в ISPmanager или непосредственно через FTP.

Иногда размер дампа не позволяет использовать web-интерфейс MySQL. В таком случае, импорт осуществляется с помощью SSH-доступа. Используя подключение SSH, ввести команду как в примере, приведенном ниже.

mysql -uпользователь -pпароль имя_бд < ourdbfile.sql

В данном примере:

  • «пользователь» — наименование пользователя в БД;
  • «пароль» — пароль вышеуказанного пользователя;
  • «имя_бд» — наименование импортируемой БД (например, «test_db»);
  • «ourdbfile.sql» — наименование файла импортируемой БД (в данном примере файл расположен в корневой папке хостинга).

После флагов « -u » и « -p » пробела быть не должно.

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

Надежный хостинг для сайта. 14 дней - бесплатно!

Переносим базы данных правильно

В любой непонятной ситуации пользуйтесь инструкцией от «Спринтхост» по переносу баз данных.

2.3K открытий
Что такое база данных?

База данных (БД) — это структурированный набор информации, с которой сайт непосредственно взаимодействует. Например, у онлайн-магазина в БД хранятся позиции товаров, у новостных агрегаторов — посты и сами новости, практически у всех видов сайтов там хранится информация о пользователях, в особенности если существует возможность создания своего личного кабинета.

Потерять базу данных — это огромная проблема, так как восстановить информацию будет затруднительно. Именно поэтому нужно аккуратно подходить к вопросу хранения и переноса БД.

Способы переноса базы данных

БД нужно переносить, если вы собрались менять хостинг. Обычно такой переезд включает в себя перенос всей информации и данных, находящихся на аккаунте. Некоторые хостинги, например, Спринтхост, могут бесплатно перенести и сайты, и базы данных к себе, вам нужно только попросить об этом техподдержку. Но эта инструкция для тех, кто хочет сам разобраться во всех тонкостях.

Вариантов переезда не так много: через файловый менеджер, через FTP или SSH — но все они связаны с тем, что нужно создать дамп существующей базы данных.

Дамп — это, по сути, копия БД в формате .sql, набор инструкций для воссоздания структуры базы данных и наполнения ее информацией. То есть если открыть этот файл в текстовом документе, то в нем вы найдете набор команд SQL. Дамп также можно использовать в качестве резервной копии и хранить его на локальном компьютере. В случае утери всей БД, вы сможете восстановиться из дампа.

Создать дамп можно несколькими способами:

  • В панелях управления хостингов иногда присутствует возможность скачать дамп одной кнопкой. Например, в Спринтхост это можно сделать через раздел «Базы данных» Панели управления. Достаточно кликнуть по названию нужной БД и нажать кнопку «Скачать резервную копию». Там же можно и загрузить уже существующий дамп на хостинг;
  • В веб-интерфейсе phpMyAdmin во вкладке «Экспорт»;
  • Утилитой mysqldump в консоли.

Важно! Перед переносом БД на другой хостинг нужно на нем создать пустую базу, куда и будут загружаться данные.

Качаем дамп через phpMyAdmin

phpMyAdmin — веб-интерфейс для работы с базами данных MySQL. Он доступен как в Спринтхост, так и у подавляющего большинства других площадок.

1. Авторизоваться в интерфейсе можно как обычным пользователем (тогда отобразятся все базы данные), так и под логином конкретной базы данных (этот способ удобен, если нужно предоставить доступ стороннему разработчику для работы с конкретной БД);

Панель входа в phpMyAdmin от Спринтхост

2. В левой части интерфейса есть список баз, кликните по нужной вам.

3. Затем в правой части зайдите во вкладку «Экспорт» и нажмите «Вперед».

4. Браузер либо предложит скачать дамп на локальный компьютер, либо автоматически это сделает. В любом случае у вас должен быть готовый дамп.

5. Чтобы загрузить дамп на новый хостинг, нужно выполнить те же действия, только перейти во вкладку «Импорт», кликнуть на «Обзор», выбрать дамп на компьютере и нажать «Вперед».

У phpMyAdmin дружественный интерфейс, поэтому с ним легко работать.

Способ посложнее — через консоль

Способ подключения по SSH зависит от операционной системы, на которой вы работаете. У Linux это встроенная консоль, а у Windows — SSH-клиент PuTTY, который нужно сначала скачать. Для создания дампа БД в консоли необходимо использовать утилиту mysqldump.

1. Соединитесь с сервером по SSH:

Здесь login — логин в Панели управления, domain.ru — любой из доменов, размещаемых на хостинге. Вместо домена можно указать IP-адрес сервера, который можно посмотреть в Панели управления.

2. Введите пароль для входа в Панель управления. Не переживайте, что в консоли ничего не вводится — это такая защита от «лишних глаз»;

3. После ввода пароля можно создать дамп следующей командой:

mysqldump -u user -p dbname > dump.sql

user — это имя пользователя вашей БД, dbname — название БД, dump.sql — название файла, в который будет сохранен дамп.

4. Введите пароль пользователя БД (не перепутайте с паролем для входа по SSH, они могут отличаться);

5. Если все сделано правильно, то дамп вы найдете в файловом менеджере. Его можно скачать напрямую оттуда или с помощью FTP.

Порой консоль может выдать такую ошибку «mysqldump: Error: 'Access denied; you need (at least one of) the PROCESS privilege(s) for this operation' when trying to dump tablespaces». Не пугайтесь, она ни на что не влияет, дамп спокойно создастся.

Чтобы импортировать созданный дамп в новую БД, нужно загрузить его в файловый менеджер хостинга. Делается это точно так же как и при скачивании дампа из файлового менеджера: либо через Панель управления, либо через FTP.

1. Снова подключаемся по SSH к хостингу, на который переносим БД, и вводим пароль;

2. Переходим в директорию (папку), где лежит файл с дампом, при помощи команды cd. Если он находится в корневой папке, то переходить никуда не нужно — оставайтесь на месте:

cd domains/domain.ru

«domains/domain.ru» — это путь до директории domain.ru.

3. В нужной директории вводим:

mysql -u user -p dbname < dump.sql

user — имя пользователя вашей БД, dbname — название вашей БД, dump.sql — имя файла дампа, который нужно импортировать;

4. Если утилита mysql завершила работу без ошибок, дамп будет корректно загружен в БД.

Скачиваем дамп через FTP

Через FTP нельзя создать дамп и загрузить его сразу в БД, но можно скачать существующий к себе на компьютер или, наоборот, «забросить» его в файловый менеджер хостинга, а потом уже при помощи консоли перенести в базу данных. Для подключения существует несколько FTP-клиентов, но самый популярный и известный — FileZilla. Данные по подключению уточните у вашего хостинг-провайдера, мы будем рассказывать на примере Спринтхост.

1. Для подключения удобно использовать панель быстрого соединения в верхней части программы. Заполните поля: хост – IP-адрес вашего аккаунта, имя пользователя – логин от Панели управления и пароль пользователя. По умолчанию для соединения FileZilla использует 21 порт;

2. Нажмите кнопку «Быстрое соединение»;

3. Если подключение прошло успешно, то в левой части интерфейса вы увидите папки и файлы своего компьютера, а справа — директории сервера, к которому вы подключились. Теперь можно спокойно переносить дамп, а затем при помощи консоли загрузить его в базу данных.

Если ничего не получается?

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

Если все же вы на каком-то шаге зашли в тупик, что-то не работает и у вас ничего не получается, то обязательно пишите в поддержку. Поддержка Спринтхост работает круглосуточно, поэтому поможет в любое время и подскажет, в чем была ошибка. Техподдержка вообще может все своими ручками перенести, она будет только рада помочь клиенту. Кроме того, можно обратиться к Базе знаний, где можно найти еще больше инструкций.

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

У меня есть сервер с очень большой базой данных mysql (160 ГБ). Как легко перенести эту БД на другой сервер?

Ответ 1

Когда вы говорите «переехать на другой сервер», мы предполагаем, что вы хотите переехать на другой сервер с MySQL, а не на другой SQL-сервер (т. е. postrgres или MSSQL).

В общем случае есть два варианта. Перенести каталог /var/lib/mysql на новый сервер как есть или выполнить процесс экспорта и импорта.

Копирование всего каталога mysql означает перенос меньшего количества данных и точную репликацию базы данных с одной машины на другую. Однако версии MySQL должны быть одинаковыми (я полагаю, что теоретически незначительные версии могут меняться, но я бы не стал на это рассчитывать). Вы можете остановить MySQL, распарсить каталог и с помощью «scp» скопировать его на другую машину. Затем распакуйте каталог на другой машине и запустите MySQL. Если вы хотите делать эту копию регулярно, возможно, вам стоит подумать о том, чтобы сделать прямой rsync каталога lib, чтобы последующие запуски команды rsync копировали только различия.

Процесс экспорта/импорта создаст массивный текстовый файл со всеми вашими данными, сохраненными в виде операторов вставки SQL (и с операторами создания таблиц в начале для настройки базы данных). Его можно будет импортировать в другую версию базы данных MySQL, но, опять же, если версии баз данных сильно отличаются, то все может пойти не так. Обычно лучше держать версии MySQL одинаковыми. Основная проблема при выполнении этого способа заключается в том, что при 160 Гб данных, уже имеющихся в вашей базе, дамп будет очень большим, поскольку в нем будут присутствовать дополнительные данные из операторов SQL. Вы можете использовать некоторые из перечисленных выше команд pipe для отправки данных на удаленную машину или вы можете сделать дамп файла (пропустив его через gzip для сжатия) и передать его через scp (при условии, что у вас достаточно места на диске).

mysqldump -u -p | gzip > db_dump.sql.gz

Другая техника, которую вы можете использовать, заключается в передаче команды mysqldump через gzip, затем через netcat (который отправляет ее по сети) в другой процесс netcat, запущенный на серверной машине, который передает ее в gzip и, наконец, в mysql. Преимущество этого способа в том, что данные сжимаются по мере прохождения по сети и не создают временных файлов. На целевой машине:

nc -l 55555 | gzip -d -c | mysql -u -p

На исходной машине:

mysqldump -u -p | gzip | nc 55555

Надеюсь, это поможет объяснить некоторые вопросы. Проверьте команды на странице man, так как у меня нет под рукой базы данных MySQL, чтобы проверить это.

Ответ 2

  1. Отключите службы MySQL на сервере A .
  2. Упакуйте каталог данных MySQL (может быть найден в каталоге /var/lib/mysql), который содержит все данные .
  3. Скопируйте конфигурацию MySQL (может быть найдена в /etc/mysql/my.cnf).
  4. Скопируйте оба файла через SSH/SCP на сервер B.
  5. Извлеките данные, поместите файл конфигурации в те же директории.
  6. (Пере)запустите службы MySQL на сервере B.
  7. Вы можете найти путь к вашей директории данных MySQL в файле конфигурации MySQL (my.cnf).

Ответ 3

Базы данных MySQL хранятся очень простым способом:

dir = имена баз данных файлы в dir — это таблицы, индексы и т. д.

Поэтому найдите, где находятся ваши базы данных — возможно, что-то вроде этого:

/var/lib/mysql

Здесь у вас будут все ваши базы данных, а в них — таблицы.

Теперь, когда вы нашли их, остановите MySQL и просто заархивируйте структуру каталогов.

tar -zcf mysqldatabases.tar.gz *.

Теперь у вас есть все материалы MySQL в одном заархивированном файле. Скопируйте его в каталог данных нового сервера и распакуйте/разархивируйте его.

Мы будем очень благодарны

если под понравившемся материалом Вы нажмёте одну из кнопок социальных сетей и поделитесь с друзьями.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *