Docker搭建MySQL主从复制

  • 搭建主从复制数据库

    3.1 配置主Master库

    ​ 3.1.1 进入主库挂载配置文件my.cnf,加入以下配置并重启docker容器

    [mysqld]
    ## 同一局域网内注意要唯一
    server-id=100  
    ## 开启二进制日志功能,可以随便取(关键)
    log-bin=mysql-bin

    ​ 3.1.2 在主Master库执行语句

    CREATE USER 'slave'@'%' IDENTIFIED BY '123456';
    GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';

    ​ 为防止后面出现报错[Authentication plugin ‘caching_sha2_password’ cannot be loaded],执行下面语句

    ALTER USER 'slave'@'%' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER;   #修改加密规则 
    ALTER USER 'slave'@'%' IDENTIFIED WITH mysql_native_password BY 'password';   #更新一下用户的密码 
    FLUSH PRIVILEGES;
    alter user 'slave'@'%' identified by '123456';

    最后执行语句获取File, Position

    show master status;

    3.2 配置从Slave库

    ​ 3.2.1 进入从库挂载配置文件my.cnf,加入以下配置并重启docker容器

    [mysqld]
    ## 设置server_id,注意要唯一
    server-id=101  
    ## 开启二进制日志功能,以备Slave作为其它Slave的Master时使用
    log-bin=mysql-slave-bin   
    ## relay_log配置中继日志
    relay_log=edu-mysql-relay-bin

    ​ 3.2.2 链接主从库,在从库执行语句

    change master to master_host='192.168.47.128', master_user='slave', master_password='123456', master_port=3306, master_log_file='mysql-bin.000001', master_log_pos= 5938, 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秒

    ​ 3.2.3 查看主从同步状态

    show slave status ;