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. Войдите в мастер, чтобы изменить конфигурацию
3. Войдите в ведомое устройство, чтобы изменить конфигурацию.
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. Тест репликации ведущий-ведомый
- Создайте тестовую базу данных в ведущем и сгенерируйте тестовую базу данных в подчиненном.