docker 安装mysql 主从复制
一、安装mysql
# docker run -p 3306:3306 --name master -e MYSQL_ROOT_PASSWORD=root -di --restart=always mysql:5.6.46
docker run -p 主机端口:容器端口 --name 自定义容器名 -i -t -d -v 主机目录:容器目录:ro 镜像ID或镜像名:TAG
#--name 指定容器名,可自定义,不指定自动命名
#-i以交互模式运行容器
#-t分配一个伪终端,即命令行,通常-it组合来使用
#-p指定映射端口,讲主机端口映射到容器内的端口
#-d后台运行容器
#-V指定挂载主机日录到容器日录,默认为rw读写模式,ro表示只读
#-e MYSQL_ROOT_PASSWORD=root 设置MySQL默认密码
# --restart=always 表示此容器开机启动,只要docker也设置了开机自启,docker不死
# 安装master 端口号为:3306
docker run -p 3306:3306 --name master -e MYSQL_ROOT_PASSWORD=root -di --restart=always mysql:5.6.46
# 安装slave 端口号为:3307
docker run -p 3307:3306 --name slave -e MYSQL_ROOT_PASSWORD=root -di --restart=always mysql:5.6.46
# 安装slave2 端口号为:3308
docker run -p 3308:3306 --name slave2 -e MYSQL_ROOT_PASSWORD=root -di --restart=always mysql:5.6.46
二、进入master容器,修改配置文件
两种进入容器的方式:任选一种即可
docker exec -it 2sdf34sdfsw /bin/bash // 2sdf34sdfsw 为容器id
docker exec -it master /bin/bash // master为自定义容器名字
进入 master容器 目录准备修改配置文件:
若发现容器内没有 安装 vim 命令的时候,输入一下命令先安装vim
apt-get update
apt-get install vim
[mysqld]
## 同一局域网内注意要唯一
server-id=100
## 开启二进制日志功能,可以随便取(关键)
log-bin=master-bin
binlog-format=ROW // 二级制日志格式,有三种 row,statement,mixed
binlog-do-db=数据库名 //同步的数据库名称,如果不配置,表示同步所有的库
配置完成后重启mysql服务:
service mysql restart
方法一:在Navicat中赋予用户权限:
方法二:
重新进入容器:
两种进入【master容器】的方式:任选一种即可
docker exec -it 2sdf34sdfsw /bin/bash // 2sdf34sdfsw 为容器id
docker exec -it master /bin/bash // master为自定义容器名字
登录到mysql客户端:
mysql -uroot -proot
授予用户 [slave] REPLICATION SLAVE权限和REPLICATION CLIENT权限
mysql> CREATE USER 'slave'@'%' IDENTIFIED BY '123456';
Query OK, 0 rows affected (0.00 sec)
mysql> GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';
Query OK, 0 rows affected (0.00 sec)
三、配置slave
docker exec -it slave /bin/bash
修改配置文件:
[mysqld]
## 设置server_id,注意要唯一
server-id=101
## 开启二进制日志功能,以备Slave作为其它Slave的Master时使用
log-bin=mysql-slave-bin
## relay_log配置中继日志
relay_log=mysql-relay-bin
read_only=1 ## 设置为只读,该项如果不设置,表示slave可读可写
配置完成后重启服务:
service mysql restart
四、开启master-slave主从复制
进入master容器内,的mysql【客户端】查看master的状态:
# 进入容器
docker exec -it master /bin/bash
# 进入客户端
mysql -uroot -proot
# 展示状态
show master status;
记住file和position栏对应的内容:
进入到Slave库myslq【客户端】,执行如下命令:
change master to master_host='172.18.0.2', master_user='root', master_password='task,.123', master_port=3306, master_log_file='master-bin.000001', master_log_pos=913, master_connect_retry=30;
【注意:在配置slave的时候,不要操作 master,否则 maser中的 position 会发生变化】
命令说明:
master_host :Master库的地址,指的是容器的独立ip,可以通过
docker inspect --format='{{.NetworkSettings.IPAddress}}' 容器名称 | 容器id查询容器的IP 进行查询
如下所示:
master_port:Master的端口号,指的是容器的端口号
master_user:用于数据同步的用户
master_password:用于同步的用户的密码
master_log_file:指定 Slave 从哪个日志文件开始复制数据,即上文中提到的 File 字段的值
master_log_pos:从哪个 Position 开始读,即上文中提到的 Position 字段的值
master_connect_retry:如果连接失败,重试的时间间隔,单位是秒,默认是60秒
在Slave 中的mysql终端执行命令;用于查看主从同步状态
show slave status \G
在slave中mysql的终端执行命令:
# 开启主从复制
start slave;
# 再次查看状态
show slave status \G
如何停止从服务复制功能
在slave容器内的 mysql 客户端内执行:
使用stop slave;
命令
如何重新配置主从
在slave容器内的 mysql 客户端内执行:
使用这两个命令 stop slave;
reset master;