一:提前创建好挂载目录
# 主数据库data文件夹
mkdir -p /usr/docker/mysql/master/data/
# 主数据库配置文件夹
mkdir -p /usr/docker/mysql/master/conf.d/
# 从数据库data文件夹
mkdir -p /usr/docker/mysql/slave/data/
# 从数据库配置文件夹
mkdir -p /usr/docker/mysql/slave/conf.d/
在各自的 conf.d 文件夹中创建 my.cnf 配置文件
# 主库
cd /usr/docker/mysql/master/conf.d/
touch my.cnf
# 从库
cd /usr/docker/mysql/slave/conf.d/
touch my.cnf
二:运行MySQL容器 5.7 为例子
主数据库
docker run \
--privileged=true \
-v /usr/docker/mysql/master/conf.d/my.cnf:/etc/my.cnf \
-v /usr/docker/mysql/master/data/:/var/lib/mysql \
-p 3366:3306 \
--name master-mysql1 \
-e MYSQL_ROOT_PASSWORD='root' \
-d mysql:5.7
从数据库
docker run \
--privileged=true \
-v /usr/docker/mysql/slave/conf.d/my.cnf:/etc/my.cnf \
-v /usr/docker/mysql/slave/data/:/var/lib/mysql \
-p 3367:3306 \
--name slave-mysql1 \
-e MYSQL_ROOT_PASSWORD='root' \
-d mysql:5.7
三:修改主从库配置文件
主库
vim /usr/docker/mysql/master/conf.d/my.cnf
[mysqld]
## 同一局域网内注意要唯一
server-id=100
## 开启二进制日志功能,可以随便取(关键)
log-bin=mysql-bin
从库
vim /usr/docker/mysql/slave/conf.d/my.cnf
[mysqld]
## 设置server_id,注意要唯一
server-id=101
## 开启二进制日志功能,以备Slave作为其它Slave的Master时使用
log-bin=mysql-slave-bin
## relay_log配置中继日志
relay_log=edu-mysql-relay-bin
四:重启主从库数据库服务
主库
# 进入容器
docker exec -it master-mysql1 /bin/bash
# 重启MySQL服务
service mysql restart
# 退出容器
exit
# 启动容器
docker start master-mysql1
从库
# 进入容器
docker exec -it slave-mysql1 /bin/bash
# 重启MySQL服务
service mysql restart
# 退出容器
exit
# 启动容器
docker start slave-mysql1
五:进入主库容器创建Slave用户
# 进入容器
docker exec -it master-mysql1 /bin/bash
# 进入MySQL
mysql -uroot -proot
# 创建slave用户
CREATE USER 'slave'@'%' IDENTIFIED BY '123456';
# 授予权限
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';
六:查看主库的信息
# 查看信息
show master status;
记住File 和 Position 的值
File和Position字段的值后面将会用到,在后面的操作完成之前,需要保证Master库不能做任何操作,否则将会引起状态变化,File和Position字段的值变化。
七:查看主库的ip地址
docker inspect --format='{{.NetworkSettings.IPAddress}}' master-mysql1
八:进入Slave数据库
#
docker exec -it slave-mysql1 /bin/bash
# 进入MySQL
mysql -uroot -proot
# 执行同步脚本
change master to master_host='172.17.0.5', master_user='slave', master_password='123456', master_port=3306, master_log_file='mysql-bin.000001', master_log_pos=617, master_connect_retry=30;
参数解析
- master_host :Master的地址
- master_port:Master的端口号,指的是容器的端口号
- master_user:用于数据同步的用户
- master_password:用于同步的用户的密码
- master_log_file:指定 Slave 从哪个日志文件开始复制数据,即上文中提到的 File 字段的值
- master_log_pos:从哪个 Position 开始读,即上文中提到的 Position 字段的值
- master_connect_retry:如果连接失败,重试的时间间隔,单位是秒,默认是60秒
九:查看Slave主从状态
# 在slave终端执行
show slave status \G;
正常情况下,SlaveIORunning 和 SlaveSQLRunning 都是No,因为我们还没有开启主从复制过程。使用start slave;
开启主从复制过程,然后再次查询主从同步状态show slave status \G;
。
十:主从复制排错
使用start slave
开启主从复制过程后,如果SlaveIORunning一直是Connecting,则说明主从复制一直处于连接状态,这种情况一般是下面几种原因造成的,我们可以根据 Last_IO_Error提示予以排除。
-
网络不通
检查ip,端口
-
密码不对
检查是否创建用于同步的用户和用户密码是否正确
-
pos不对
检查Master的 Position
十一:测试主从复制
Master:
Slave:
以根据 Last_IO_Error提示予以排除。
-
网络不通
检查ip,端口
-
密码不对
检查是否创建用于同步的用户和用户密码是否正确
-
pos不对
检查Master的 Position
十一:测试主从复制
Master:
Slave: