基础信息:
Unbutu 20.04
docker版本: 20.10.12
docker-compose版本: 1.29.2
公网ip:172.121.123.221
mysql_version: 5.7.37
mysql_user_root : 123456
mysql_user_slave : 123456
1. 拉取镜像-创建docker网络
docker pull mysql:5.7.37;
docker network create -d bridge --gateway 10.0.0.1 --subnet 10.0.0.0/24 net-mysql
2. 准备compose文件:
# 文件树:
# - mysql
# ---- docker-compose.yaml
# ---- mysql.env
# compose-mysql-5.7.yaml
version: "3"
services:
mysql-master:
image: mysql:5.7.37
container_name: mysql-master
env_file:
- mysql.env
volumes:
- /root/volume/mysql/master/conf:/etc/mysql
- /root/volume/mysql/master/log:/var/log/mysql
- /root/volume/mysql/master/data:/var/lib/mysql
ports:
- "3306:3306"
- "33060:33060"
restart: always
privileged: true
networks:
net-mysql:
ipv4_address: 10.0.0.10
mysql-slave:
image: mysql:5.7.37
container_name: mysql-slave
env_file:
- mysql.env
volumes:
- /root/volume/mysql/slave/conf:/etc/mysql
- /root/volume/mysql/slave/log:/var/log/mysql
- /root/volume/mysql/slave/data:/var/lib/mysql
ports:
- "3307:3306"
- "33061:33060"
restart: always
privileged: true
networks:
net-mysql:
ipv4_address: 10.0.0.20
networks:
net-mysql:
external: true
# mysql.env
MYSQL_ROOT_PASSWORD=123456
3. 开始
3.1 进入mysql目录
docker-compose up;
# 容器启动后,停止两个容器
docker stop mysql-master;
docker stop mysql-slave;
3.2 准备两个my.cnf
# /root/volume/mysql/master/conf/my.cnf
[mysqld]
## 设置server_id,同一局域网中需要唯一
server_id=101
## 开启二进制日志功能
log-bin=mall-mysql-bin
## 设置二进制日志使用内存大小(事务)
binlog_cache_size=2M
## 设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed
## 二进制日志过期清理时间。默认值为0,表示不自动清理。
expire_logs_days=4
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062
# /root/volume/mysql/slave/conf/my.cnf
[mysqld]
## 设置server_id,同一局域网中需要唯一
server_id=102
## 开启二进制日志功能,以备Slave作为其它数据库实例的Master时使用
log-bin=mall-mysql-slave1-bin
## 设置二进制日志使用内存大小(事务)
binlog_cache_size=2M
## 设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed
## 二进制日志过期清理时间。默认值为0,表示不自动清理。
expire_logs_days=4
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062
## relay_log配置中继日志
relay_log=mall-mysql-relay-bin
## log_slave_updates表示slave将复制事件写进自己的二进制日志
log_slave_updates=1
## slave设置为只读(具有super权限的用户除外)
read_only=1
3.3 记录mysql-master信息
docker restart mysql-master;
docker exec -it mysql-master bash;
mysql -uroot -p;
create user 'slave'@'%' identified by '123456';
grant replication slave,replication client on *.* to 'slave'@'%';
FLUSH PRIVILEGES;
show master status;
记录信息:File(日志文件名称):mall-mysql-bin.000001 和 Position(日志文件地址):769
File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
---|---|---|---|---|
mall-mysql-bin.000001 | 769 | mysql |
# 退出 mysql
exit;
# 退出容器
ctrl p q
3.4 重启mysql-salve
docker restart mysql-slave;
docker exec -it mysql-slave bash;
mysql -uroot -p;
change master to master_host='10.0.0.10', master_user='slave', master_password='123456', master_port=3306, master_log_file='mall-mysql-bin.000001', master_log_pos=769, master_connect_retry=30;
start slave;
show slave status\G;
查看
Slave_IO_Running是否为:Yes
Slave_SQL_Running是否为:Yes
FLUSH PRIVILEGES;
# 退出 mysql
exit;
# 退出容器
ctrl p q
4. 主从已经搭建完成
4.1 远程连接
主库设置后,从库会自动修改root远程信息
docker exec -it mysql-master bash;
mysql -uroot -p;
grant all on *.* to 'root'@'%' identified by '123456' with grant option;
FLUSH PRIVILEGES;