• 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库会同步修改

  • 相关阅读:
    竞态问题 + axios 取消请求
    RS笔记:深度推荐模型之多任务学习PLE模型 [RecSys 2020 最佳论文 腾讯]
    用Markdown写Html和.md也就图一乐,真骚操作还得用来做PPT
    复习七:队列
    Git多人开发解决冲突案例
    为什么说网络安全是IT行业最后的红利?是风口行业?
    Megatron-LM GPT 源码分析(二) Sequence Parallel分析
    postgresql数据库之分割字符串函数
    1024程序员节特辑 | 深度解析C/C++内存管理(建议收藏!!)
    Unity中Shader光照模型Blinn-Phong原理及实现
  • 原文地址:https://blog.csdn.net/qq_35699473/article/details/128132604