• 使用docker容器搭建MySQL主从复制


    1、拉取mysql镜像

    docker pull mysql
    
    • 1

    2、创建主节点docker容器

    docker run --name mysql-master -p 3306:3306 -v /root/docker/mysql/master:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456 -d mysql
    
    • 1

    创建从节点docker容器

    docker run --name mysql-slave -p 3307:3306 -v /root/docker/mysql/slave:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456 -d mysql
    
    • 1

    这里通过挂载目录的方式使mysql的配置文件生效。然后,分别在两个节点导入数据库user_db。

    3、在/root/docker/mysql/master下创建主节点的配置文件mysql.cnf

    [mysqld]
    log-bin=mysql-bin  # 启用二进制日志
    server-id=1   # 服务器唯一ID,可以任意设置,但必须唯一
    binlog-ignore-db=mysql  # 不要复制的数据库
    binlog-ignore-db=information_schema
    binlog-ignore-db=performance_schema
    binlog-ignore-db=sys
    binlog-do-db=user_db     # 要复制的数据库名
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    注意,mysql的配置文件开头要加上[mysqld],我就是一开始没加这个东西导致配置怎么改都不生效,浪费了很多时间。这里设置了复制数据库user_db。重启容器,使配置生效。

    4、在/root/docker/mysql/slave下创建从节点的配置文件mysql.cnf

    [mysqld]
    server-id=2
    relay-log=mysql-relay
    
    • 1
    • 2
    • 3

    重启容器,使配置生效。

    5、使用客户端连接主节点,执行如下命令

    show master status
    
    • 1

    查看节点状态
    在这里插入图片描述
    在从节点执行如下命令

    change master to 
    master_host='192.168.182.128',master_port=3306, master_user='root',master_password='123456',
    master_log_file='mysql-bin.000003',master_log_pos=157;
    
    • 1
    • 2
    • 3

    实现复制。其中,master_log_file和master_log_pos分别对应上图中的File和Position。

    6、在从节点执行

    start slave
    
    • 1

    开启复制。执行

    show slave status
    
    • 1

    查看复制状态,
    在这里插入图片描述
    在这里插入图片描述
    出现两个Yes,说明主从复制已经搭建完成。
    尝试向主节点的表中添加记录,会自动复制到从节点上。

  • 相关阅读:
    提升系统性能之Future模式
    船用电缆和普通电缆有什么区别?
    【788. 旋转数字】
    2023年第十六届山东省职业院校技能大赛高职组“软件测试”赛项样题
    网络请求【小程序】
    HBase的flush(刷写)及compact(合并)机制
    Vue3.0项目——打造企业级音乐App(二)图片懒加载、v-loading指令的开发和优化
    T2I-Adapter:增强文本到图像生成的控制能力
    A - Turn the Rectangles
    华为综合测评攻略
  • 原文地址:https://blog.csdn.net/woshihedayu/article/details/126079465