docker搭建mysql主从复制
- 拉取mysql镜像命令:docker pull mysql:5.7
1.启动master,slave
- 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.进入到master修改配置
- docker exec -it 627a2368c865 bash
- cd /etc/mysql
vim my.cnf
- 这个时候会报错 bash: vi: command not found,需要安装vim
- apt-get install vim
- apt-get update
- apt-get install vim
- 在my.cnf中添加如下配置
[mysqld] ## 同一局域网内注意要唯一 server-id=100 ## 开启二进制日志功能,可以随便取(关键) log-bin=mysql-bin
- 配置完成之后,需要重启mysql服务使配置生效。使用service mysql restart完成重启。重启mysql服务时会使得docker容器停止,我们还需要docker start master启动容器。
- Master数据库创建数据同步用户,授予用户 slave REPLICATION SLAVE权限和REPLICATION CLIENT权限,用于在主从库之间同步数据。
- docker exec -it 627a2368c865 bash 进入到master容器中
- mysql -u root -p
- 输入密码
- CREATE USER 'slave'@'%' IDENTIFIED BY '123456';
- GRANT REPLICATION SLAVE, REPLICATION CLIENT ON . TO 'slave'@'%';
3.进入到slave修改配置
- 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服务使配置生效。使用service mysql restart完成重启。重启mysql服务时会使得docker容器停止,我们还需要docker start slave启动容器。
4.进入master容器
- 进入到mysql,mysql -u root -p
- show master status;
- 记录File(mysql-bin.000001), Position(617)
5.退出到docker容器。
- 查询master和slave的ip:
- docker inspect --format='{{.NetworkSettings.IPAddress}}' master (127.0.0.2)
- docker inspect --format='{{.NetworkSettings.IPAddress}}' slave (127.0.0.3)
6.进入slave容器
- 进入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开启主从复制
- 在Slave 中的mysql终端执行show slave status \G;用于查看主从同步状态
- SlaveIORunning 和 SlaveSQLRunning 都是No
- start slave开启主从复制
- 再次查询主从同步状态show slave status \G;
8.主从复制测试
- 在master创建一个test数据库,在slave中也会生成一个test数据库。