Адрес фактического центра электронной коммерции SpringBoot (25k+star):GitHub.com/macro-positive/…
Резюме
В этой статье мы начнем с принципа репликации «главный-ведомый» MySql и подробно представим конструкцию репликации «главный-ведомый» MySql в среде Docker, взяв в качестве примера главный экземпляр и подчиненный экземпляр для достижения репликации «главный-подчиненный».
Что такое репликация Master-Plave?
The master-slave replication refers to the transfer of the DDL and DML operations of the primary database through the binary log to the slave database, and then re-execute these logs from the database, so that the data from the database and the primary database согласуется.
Принцип репликации master-slave
- Основная библиотека MySql будет записывать изменения данных как события в двоичном журнале Binlog при фиксации транзакции;
- Главная библиотека помещает события из двоичного файла журнала Binlog в журнал ретрансляции Relay Log подчиненной библиотеки, а затем подчиненная библиотека повторяет операцию изменения данных в соответствии с журналом реле и обеспечивает согласованность данных между главной библиотекой и подчиненной библиотекой. библиотека через логическую репликацию;
- MySql выполняет репликацию данных между главной и подчиненной библиотеками через три потока, в которых поток Binlog Dump выполняется в главной библиотеке, а поток ввода-вывода и поток SQL выполняются в подчиненной библиотеке;
- При запуске репликации в подчиненной библиотеке сначала создайте поток ввода-вывода для подключения к главной библиотеке, затем главная библиотека создает поток Binlog Dump для чтения событий базы данных и отправки их в поток ввода-вывода, а поток ввода-вывода поток получает данные о событии и обновляет их в ведомой библиотеке. Перейдите к журналу ретрансляции. Журнал ретрансляции библиотеки, а затем прочитайте и примените обновленные события базы данных в журнале ретрансляции. Журнал ретрансляции из потока SQL в библиотеке, как показано на следующий рисунок.
Создайте основной экземпляр
- Запустите мастер-экземпляр Mysql:
docker run -p 3307:3306 --name mysql-master \
-v /mydata/mysql-master/log:/var/log/mysql \
-v /mydata/mysql-master/data:/var/lib/mysql \
-v /mydata/mysql-master/conf:/etc/mysql \
-e MYSQL_ROOT_PASSWORD=root \
-d mysql:5.7
- в папке конфигурации mysql
/mydata/mysql-master/conf
Создайте файл конфигурации вmy.cnf
:
touch my.cnf
- Измените файл конфигурации my.cnf, информация о конфигурации выглядит следующим образом:
[mysqld]
## 设置server_id,同一局域网中需要唯一
server_id=101
## 指定不需要同步的数据库名称
binlog-ignore-db=mysql
## 开启二进制日志功能
log-bin=mall-mysql-bin
## 设置二进制日志使用内存大小(事务)
binlog_cache_size=1M
## 设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed
## 二进制日志过期清理时间。默认值为0,表示不自动清理。
expire_logs_days=7
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062
- Перезапустите экземпляр после изменения конфигурации:
docker restart mysql-master
- Входить
mysql-master
Контейнер:
docker exec -it mysql-master /bin/bash
- Подключитесь к клиенту с помощью команды входа mysql в контейнере:
mysql -uroot -proot
- Создайте пользователя для синхронизации данных:
CREATE USER 'slave'@'%' IDENTIFIED BY '123456';
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';
Построить из примера
- Запустите подчиненный экземпляр mysql:
docker run -p 3308:3306 --name mysql-slave \
-v /mydata/mysql-slave/log:/var/log/mysql \
-v /mydata/mysql-slave/data:/var/lib/mysql \
-v /mydata/mysql-slave/conf:/etc/mysql \
-e MYSQL_ROOT_PASSWORD=root \
-d mysql:5.7
- в папке конфигурации mysql
/mydata/mysql-slave/conf
Создайте файл конфигурации вmy.cnf
:
touch my.cnf
- Измените файл конфигурации my.cnf:
[mysqld]
## 设置server_id,同一局域网中需要唯一
server_id=102
## 指定不需要同步的数据库名称
binlog-ignore-db=mysql
## 开启二进制日志功能,以备Slave作为其它数据库实例的Master时使用
log-bin=mall-mysql-slave1-bin
## 设置二进制日志使用内存大小(事务)
binlog_cache_size=1M
## 设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed
## 二进制日志过期清理时间。默认值为0,表示不自动清理。
expire_logs_days=7
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062
## relay_log配置中继日志
relay_log=mall-mysql-relay-bin
## log_slave_updates表示slave将复制事件写进自己的二进制日志
log_slave_updates=1
## slave设置为只读(具有super权限的用户除外)
read_only=1
- Перезапустите экземпляр после изменения конфигурации:
docker restart mysql-slave
Подключить базу данных master-slave
- Подключитесь к клиенту mysql основной базы данных, чтобы просмотреть состояние основной базы данных:
show master status;
- Состояние основной базы данных отображается следующим образом:
- Входить
mysql-slave
В контейнере:
docker exec -it mysql-slave /bin/bash
- Подключитесь к клиенту с помощью команды входа mysql в контейнере:
mysql -uroot -proot
- Настройте репликацию master-slave в подчиненной базе данных:
change master to master_host='192.168.6.132', master_user='slave', master_password='123456', master_port=3307, master_log_file='mall-mysql-bin.000001', master_log_pos=617, master_connect_retry=30;
-
Описание параметров команды репликации master-slave:
- master_host: IP-адрес основной базы данных;
- master_port: рабочий порт базы данных master;
- master_user: учетная запись пользователя, созданная в базе данных master для синхронизации данных;
- master_password: пароль пользователя, созданный в базе данных master для синхронизации данных;
- Master_log_file: укажите файл журнала для копирования данных из базы данных и получить параметр файла, просматривая состояние основных данных;
- master_log_pos: укажите, откуда начинать копирование данных из базы данных, и получите параметр Position, просмотрев статус основных данных;
- master_connect_retry: интервал времени для повторной попытки соединения, в секундах.
-
Проверьте статус синхронизации master-slave:
show slave status \G;
- Статус из базы данных отображается следующим образом:
- Включить синхронизацию master-slave:
start slave;
- Проверьте состояние подчиненной базы данных и убедитесь, что она была синхронизирована:
Проверка репликации Master-Slave
Существует множество методов проверки репликации master-slave.Вы можете создать базу данных в главном экземпляре, чтобы увидеть, существует ли база данных в подчиненном экземпляре.Если она существует, это означает, что репликация master-slave была успешно установлена.
- Создайте базу данных в мастер-экземпляре
mall
;
- Просматривая базу данных экземпляра, я обнаружил, что там также есть
mall
По базе данных можно судить, что репликация master-slave успешно установлена.
публика
проект торгового центраПолный набор учебных пособий сериализуется,Обратите внимание на общедоступный номерПолучите это прямо сейчас.