Репликация master-slave MySQL на основе докера

MySQL Docker

Docker создает репликацию master-slave mysql

  • Команда вытягивания образа mysql: docker pull mysql:5.7

1. Старт мастер, раб

  • docker run -it -p 3306:3306 --name master --privileged=true -v /f/DockerServer/mysql3306/conf/conf.d:/etc/mysql/conf.d -v /f/DockerServer/mysql3306/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7
  • docker run -it -p 3307:3306 --name slave --privileged=true -v /f/DockerServer/mysql3306/conf/conf.d:/etc/mysql/conf.d -v /f/DockerServer/mysql3307/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7

2. Войдите в мастер, чтобы изменить конфигурацию

  • docker exec -it 627a2368c865 bash
  • cd /etc/mysql
  • vim my.cnf
    • В это время будет сообщено об ошибке bash:vi: команда не найдена, вам необходимо установить vim
    • apt-get install vim
    • apt-get update
    • apt-get install vim
    • Добавьте следующую конфигурацию в my.cnf
    [mysqld]
    ## 同一局域网内注意要唯一
    server-id=100  
    ## 开启二进制日志功能,可以随便取(关键)
    log-bin=mysql-bin
    
  • После завершения настройки вам необходимо перезапустить службу mysql, чтобы конфигурация вступила в силу. Используйте перезапуск службы mysql для завершения перезапуска. Перезапуск службы mysql остановит контейнер докеров.Нам также нужен мастер запуска докеров, чтобы запустить контейнер.
  • База данных master создает пользователя для синхронизации данных и предоставляет подчиненному пользователю полномочия REPLICATION SLAVE и полномочия REPLICATION CLIENT для синхронизации данных между master и slave базами данных.
  • docker exec -it 627a2368c865 bash входит в главный контейнер
  • mysql -u root -p
  • введите пароль
  • CREATE USER 'slave'@'%' IDENTIFIED BY '123456';
  • GRANT REPLICATION SLAVE, REPLICATION CLIENT ON . TO 'slave'@'%';

3. Войдите в ведомое устройство, чтобы изменить конфигурацию.

  • docker exec -it 123a2368c123 bash
  • cd /etc/mysql
  • vim my.cnf
  • apt-get install vim
    • Добавьте следующую конфигурацию в my.cnf
    [mysqld]
     ## 设置server_id,注意要唯一
     server-id=101  
     ## 开启二进制日志功能,以备Slave作为其它Slave的Master时使用
     log-bin=mysql-slave-bin   
     ## relay_log配置中继日志
     relay_log=edu-mysql-relay-bin  
    
  • После завершения настройки вам необходимо перезапустить службу mysql, чтобы конфигурация вступила в силу. Используйте перезапуск службы mysql для завершения перезапуска. Перезапуск службы mysql остановит контейнер докеров, и нам также нужен ведомый узел запуска докера для запуска контейнера.

4. Войдите в мастер-контейнер

  • Войдите в mysql, mysql -u root -p
  • show master status;
  • Файл записи (mysql-bin.000001), позиция (617)

5. Выйдите в докер-контейнер.

  • Запросите IP-адрес главного и подчиненного:
  • docker inspect --format='{{.NetworkSettings.IPAddress}}' master (127.0.0.2)
  • docker inspect --format='{{.NetworkSettings.IPAddress}}' slave (127.0.0.3)

6. Войдите в подчиненный контейнер

  • Введите mysql, mysql -u root -p
  • change master to master_host='172.17.0.2', master_user='slave', master_password='123456', master_port=3306, master_log_file='mysql-bin.000001', master_log_pos= 617, master_connect_retry=30;
  • Поле Описание
master_port:Master的端口号,指的是容器的端口号
master_user:用于数据同步的用户
master_password:用于同步的用户的密码
master_log_file:指定 Slave 从哪个日志文件开始复制数据,即上文中提到的 File 字段的值
master_log_pos:从哪个 Position 开始读,即上文中提到的 Position 字段的值
master_connect_retry:如果连接失败,重试的时间间隔,单位是秒,默认是60秒

7.slave включить репликацию master-slave

  • Выполните show slave status \G на терминале mysql в Slave, чтобы просмотреть статус синхронизации master-slave.
  • 在这里插入图片描述
  • И SlaveIORunning, и SlaveSQLRunning — нет.
  • start slave для запуска репликации master-slave
  • Снова запросите статус синхронизации master-slave, покажите статус slave \G;
  • 在这里插入图片描述

8. Тест репликации ведущий-ведомый

  • Создайте тестовую базу данных в ведущем и сгенерируйте тестовую базу данных в подчиненном.