• MySQL数据库实现主从复制,docker实现版


    我这里是在同一台电脑上使用docker实现的主从复制,在物理机上整体思路是一致的

    预备工作:安装好docker

    使用docker运行MySQL

    1. 拉取MySQL镜像
    docker pull mysql:5.7
    
    • 1
    1. 运行mysql master容器
    sudo docker run -p 33061:3306 --name mysql-master-v /mydata/mysql-master/conf:/etc/mysql/conf.d -v /mydata/mysql-master/logs:/logs -v /mydata/mysql-master/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -d mysql:5.7
    
    • 1
    1. 运行mysql slave 容器
    sudo docker run -p 33062:3306 --name mysql-slave  -v /mydata/mysql-slave/conf:/etc/mysql/conf.d -v /mydata/mysql-slave/logs:/logs -v /mydata/mysql-slave/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -d mysql:5.7
    
    • 1

    上边两个主要的区别就是端口号和对应的文件夹不一样

    配置mysql master

    1. 在目录/mydata/mysql-master/conf下新增文件,文件名my.cnf,其中内容为
    [mysqld]
    log-bin=mysql-bin ##启用二进制日志
    server_id=101  ## 设置server_id,同一局域网中需要唯一
    
    • 1
    • 2
    • 3

    这里的配置文件对应的在/etc/my.cnf,但是因为修改该文件不方便,所以这样去新增一个文件

    1. 然后重启mysql master
    sudo docker restart mysql-master
    
    • 1
    1. 创建用户并赋予REPUBLICATIONSLAVE权限。这里创建的用户名和密码都叫xiaoming

    进入mysql

    sudo docker exec -it mysql-master mysql -uroot -proot
    
    • 1

    创建用户和权限

    GRANT REPLICATION SLAVE ON *.* to 'xiaoming'@'%' identified by 'xiaoming';
    
    • 1
    1. 查看master状态
    show master status;
    
    • 1

    在这里插入图片描述
    此时就不要在主库做任何操作了,否则可能会变化,上图中的两个值后续会被用到。

    配置mysql slave

    1. 在目录/mydata/mysql-slave/conf下新增文件,文件名my.cnf,其中内容为
    [mysqld]
    server_id=102  ## 设置server_id,同一局域网中需要唯一
    
    • 1
    • 2
    1. 重启mysql slave
    sudo docker restart mysql-slave
    
    • 1
    1. 配置mysql master的数据

    登入mysql

    sudo docker exec -it mysql-slave mysql -uroot -proot
    
    • 1

    设置master,其中的mysql_log_filemaster_log_pos就是配置master时的那两个值

    change master to master_host='192.168.0.100',master_port=33061,master_user='xiaoming',master_password='xiaoming',master_log_file='mysql-bin.000001',master_log_pos=441;
    
    • 1
    1. 开启同步
    start slave;
    
    • 1
    1. 查看状态
    show slave status;
    
    或使用下列命令竖排查看
    show slave status\G;
    
    • 1
    • 2
    • 3
    • 4

    此时Slave_IO_RunningSlave_SQL_Running应都为Yes,说明设置成功

    在这里插入图片描述

    此时对master库进行修改,slave库会同步修改

  • 相关阅读:
    JAVA大学生健康电子档案系统计算机毕业设计Mybatis+系统+数据库+调试部署
    输入/输出的实用性-SOLIDWORKS 2024新功能
    第三套.py
    Keras深度学习实战——基于Inception v3实现性别分类
    ORACLE XXX序列 goes below MINVALUE 无法实例化的处理办法
    Hadoop大数据应用:Yarn 节点实现扩容与缩容
    第08篇:巧用Spring之Data Binding数据绑定
    【网络】网络入门
    MongoDB 对索引的创建查询修改删除 附代码
    计算机网络基础一
  • 原文地址:https://blog.csdn.net/qq_35699473/article/details/128132604