|
![]() |
|||||
OSS Group :: Admin :: Настройка Master-Slave репликации в MySQL |
||||||
|
Настройка Master-Slave репликации в MySQLИсходные данные
СУБД на обоих хостах запущены и работают. ТребуетсяНастроить репликацию базы replica на хосте mysql1 на хост mysql2 в режиме master-slave. Порядок действийНа хосте mysql1В файле конфигурации MySQL (
server-id=1 log-bin=/log/bin.log binlog-do-db=replica binlog-ignore-db=mysql binlog-ignore-db=test Перезапускаем демона. #service mysqld restart В консоли MySQL создаём на master-хосте пользователя с полномочиями на репликацию: $mysql -uroot -p mysql> GRANT REPLICATION SLAVE ON *.* TO 'slave_user'@'%' IDENTIFIED BY 'slave'; mysql> FLUSH PRIVILEGES; mysql> USE replica; mysql> FLUSH TABLES WITH READ LOCK; mysql> SHOW MASTER STATUS; +------------+----------+--------------+------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | +------------+----------+--------------+------------------+ | bin.000002 | 98 | replica | mysql,test | +------------+----------+--------------+------------------+ Запоминаем параметры File и Position. Далее создаём дамп реплицируемой базы: $mysqldump -uroot -p replica > replica.dump И переносим этот дамп на slave-хост. Внимание. Блокировка таблиц будет снята, если выйти из консоли MySQL. Для создания дампа базы и переноса его на slave-хост следует использовать другую пользовательскую сессию. После выполнения всех операций на slave-хосте в консоли MySQL разблокируем таблицы: mysql> UNLOCK TABLES; На хосте mysql2Создаём базу replica и наполняем её из дампа с master-хоста: $mysqladmin -uroot -p create replica $mysql -uroot -p replica < replica.dump В файле конфигурации MySQL (
server-id=2 master-host=mysql1 master-user=slave_user master-password=slave master-connect-retry=60 replicate-do-db=replica relay-log=/log/slave-relay-bin relay-log-index=/log/slave-relay-bin.index Перезапускаем демона. #service mysqld restart Затем запускаем процесс репликации в консоли MySQL (используя параметры File и Position с master-хоста):
$mysql -uroot -p
mysql> SLAVE STOP;
mysql> CHANGE MASTER TO
-> MASTER_HOST='mysql1',
-> MASTER_USER='slave_user',
-> MASTER_PASSWORD='slave',
-> MASTER_LOG_FILE='bin.000002',
-> MASTER_LOG_POS=98;
mysql> START SLAVE;
mysql> SHOW SLAVE STATUS\G
Убеждаемся в том, что параметры Slave_IO_Running и Slave_SQL_Running установлены в Yes. Краткое резюмеВ принципе репликация работает. Потенциальные проблемы:
Из несрабатывающего также стоит отметить директиву для начального переноса данных на slave-хост: mysql> LOAD DATA FROM MASTER; На данный момент, судя по всему, альтернативы переносу данных с помощью дампа не существует. Дополнительные источники информации
Дата создания: 2007-10-08 15:54:13 (Фетисов Ф. А. (faf)) Wiki::Admin Оглавление Карта раздела Изменения за сутки Изменения за неделю Изменения за месяц |
|
© 2006-2025 OSS Group. All rights reserved. | Техническая поддержка: Открытые Информационные Технологии и Системы
|
![Valid RSS feed [Valid RSS]](/files/ossg/images/banners/valid-rss-rogers.png)