Docker搭建主从数据库

基础信息:

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;

4.2 如果有防火墙,开通3306,3307

你可能感兴趣的:(Docker,运维,linux,mysql)