docker搭建MySQL主从复制

1. 搭建MySQL主从

1.1. 准备主服务器

  1. 创建一个主节点MySQL

    docker run -itd \
        -p 3307:3307 \
        -v /container/volumes/mysql-master/conf:/etc/mysql/conf.d \
        -e MYSQL_ROOT_PASSWORD=123456a \
        -e MYSQL_ROOT_HOST='%' \
        --name=mysql-master \
        mysql:8.0.23
    
  2. 修改主节点的配置文件

    vim /container/volumes/mysql-master/conf/my.cnf
    
    [mysqld]
    # 服务端口号,默认3306
    port=3307
    # 服务器唯一id,默认值1
    server-id=1
    # 设置日志的格式,默认是ROW
    binlog_format=STATEMENT
    # 二进制日志名,默认binlog
    #log-bin=binlog
    # 设置需要复制的数据库,默认复制全部数据库
    #binlog-do-db=testdb
    # 设置不需要复制的数据库
    #binlog-ignore-db=mysql
    #binlog-ignore-db=information_schema
    
  3. 重启MySQL主节点

    docker restart mysql-master
    
  4. 创建一个用户用于主从复制

    -- 创建用户
    CREATE USER 'slave'@'%' IDENTIFIED BY '123456a';
    -- 授予用户复制权限
    GRANT replication SLAVE ON *.* TO 'slave'@'%' WITH GRANT OPTION;
    -- 刷新权限
    FLUSH PRIVILEGES;
    
  5. 查看主节点的状态

    show master status;
    

    查看主节点的状态

    记录FilePosition的值。

📝binlog_format可选值:

  • STATEMENT:日志记录的是主数据库的写命令,性能高,但是now()之类的函数以及获取系统参数的操作会出现主从数据不同步的情况
  • ROW(默认):日志记录的是主数据库的写后的数据,批量操作时性能较差,解决now()、user()或@@hostname等操作主从机器上不一致的问题
  • MIXED:以上两种模式混合使用。有函数用ROW,没函数用STATEMENT,但是无法识别系统变量

1.2. 准备从服务器

  1. 创建一个从节点MySQL

    docker run -itd \
        -p 3308:3308 \
        -v /container/volumes/mysql-slave1/conf:/etc/mysql/conf.d \
        -e MYSQL_ROOT_PASSWORD=123456a \
        -e MYSQL_ROOT_HOST='%' \
        --name=mysql-slave1 \
        mysql:8.0.23
    
  2. 修改主节点的配置文件

    vim /container/volumes/mysql-slave1/conf/my.cnf
    
    [mysqld]
    # 服务端口号,默认3306
    port=3308
    # 服务器唯一id,默认值1
    server-id=2
    # 中继日志名,默认xxxx-relay-bin
    #relay-log=relay-bin
    
  3. 重启MySQL从节点

    docker restart mysql-slave1
    
  4. 配置主从关系

    ⚠️需要在从节点的MySQL上执行

    CHANGE MASTER TO master_host = '192.168.5.20',
    master_user = "slave",
    master_password = "123456a",
    master_port = 3307,
    master_log_file = "binlog.000003",
    master_log_pos = 1985;
    
  5. 重复执行上述步骤,创建slave2节点

1.3. 启动主从

启动从节点的复制功能,执行SQL:

start slave;
-- 查看状态
show slave status;

查看从节点状态

1.4. 测试主从数据同步

DROP DATABASE IF EXISTS db_user;
CREATE DATABASE db_user;

USE db_user;

CREATE TABLE t_user (
    id BIGINT UNSIGNED PRIMARY KEY auto_increment COMMENT 'id',
    username VARCHAR (32) NOT NULL COMMENT '用户名',
    gender TINYINT UNSIGNED NOT NULL COMMENT '性别(0 女 1 男)'
);

INSERT INTO t_user ( username, gender )
VALUES
	(
	'张三',
	1);
INSERT INTO t_user ( username, gender )
VALUES
	(
	@@hostname,
	0);

在主节点执行以上sql,去从节点是否可以从主节点同步数据

1.5. 停止和重置

-- 停止I/O线程和SQL线程的操作
stop slave;
-- 删除slave数据库的relaylog日志文件,并重新启用新的relaylog文件
reset slave;
-- 删除所有binlog日志文件,并将日志索引文件清空,重新开始所有新的日志文件。
-- 用于第一次进行搭建主从数据库时,进行binlog初始化工作
reset master;
  • 22
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值