docker 搭建mysql主从复制

主从复制概述

  • 主从复制是指将主数据库的 DDL 和 DML 操作通过二进制日志传到从库服务器中,然后在从库上对这些日志重新执行(也叫重做),从而使得从库和主库的数据保持同步。
  • MySQL支持一台主库同时向多台从库进行复制, 从库同时也可以作为其他从服务器的主库,实现链状复制。
  • MySQL 复制的优点主要包含以下三个方面:
  1. 主库出现问题,可以快速切换到从库提供服务。
  2. 实现读写分离,降低主库的访问压力。
  3. 可以在从库中执行备份,以避免备份期间影响主库服务。

主从复制原理

  • Master 主库在事务提交时,会把数据变更记录在二进制日志文件 Binlog 中。
  • 从库读取主库的二进制日志文件 Binlog ,写入到从库的中继日志 Relay Log 。
  • slave重做(对这些日志重新执行)中继日志中的事件,从而使得从库和主库的数据保持同步。

环境搭建

  • 下载mysql镜像

docker pull mysql:latest

  • 运行mysql主容器

sudo docker run -p 3307:3306 --name main_mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql

  • 运行mysql从容器

sudo docker run -p 3308:3306 --name slave_mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql

修改主容器配置

  • 进入主从容器

sudo docker exec -it main_mysql bin/bash

  • 更新软件

apt-get update

  • 下载vim编辑器

apt-get vim

  • 修改主容器mysql配置文件

vim /etc/mysql/my.cof

<code style="margin-left:0">[mysqld]
## 设置server_id,同一局域网中需要唯一
server_id=101 
## 指定不需要同步的数据库名称
binlog-ignore-db=mysql  
## 开启二进制日志功能
log-bin=mall-mysql-bin  
## 设置二进制日志使用内存大小(事务)
binlog_cache_size=1M  
## 设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed  
## 二进制日志过期清理时间。默认值为0,表示不自动清理。
expire_logs_days=7  
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062</code>

修改从容器配置

  • 进入从容器

sudo docker exec -it slave_mysql bin/bash

  • 更新软件

apt-get update

  • 下载vim编辑器

apt-get vim

  • 修改从容器mysql配置文件

vim /etc/mysql/my.cof

<code style="margin-left:0">[mysqld]
## 设置server_id,同一局域网中需要唯一
server_id=102
## 指定不需要同步的数据库名称
binlog-ignore-db=mysql  
## 开启二进制日志功能,以备Slave作为其它数据库实例的Master时使用
log-bin=mall-mysql-slave1-bin  
## 设置二进制日志使用内存大小(事务)
binlog_cache_size=1M  
## 设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed  
## 二进制日志过期清理时间。默认值为0,表示不自动清理。
expire_logs_days=7  
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062  
## relay_log配置中继日志
relay_log=mall-mysql-relay-bin  
## log_slave_updates表示slave将复制事件写进自己的二进制日志
log_slave_updates=1  
## slave设置为只读(具有super权限的用户除外)
read_only=1</code>

重启主容器mysql

  • 重启命令

docker restart main_mysql

  • 进入容器

docker exec -it main_mysql /bin/bash

  • 进入mysql

mysql -u root -p root

  • 创建数据同步用户

CREATE USER 'slave'@'%' IDENTIFIED BY '123456';

  • 用户授权

GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';

  • 配置刷新

flush privileges;

  • 在主数据库中查看主从同步状态

show master status;

重启从容器mysql

  • 重启命令

docker restart salve_mysql

  • 进入容器

docker exec -it salve_mysql /bin/bash

  • 进入mysql

mysql -u root -p root

  • 在从数据库中配置主从复制

change master to master_host='宿主机ip', master_user='slave', master_password='123456', master_port=3307, master_log_file='mysql-slave-bin.000002', master_log_pos=3860, master_connect_retry=30;

<code style="margin-left:0">master_host 为主容器的ip(docker 查询容器ip命令:docker inspect  main_mysql | grep IPAddress)
master_user 为主容器mysql的用户名
master_password 为主容器mysql的密码
master_log_file 为主容器mysql的File(mysql-slave-bin.000002)
master_log_pos 未主容器的Position(3860)
master_connect_retry 连接主容器的次数</code>
  • 启动slave

start slave

  • 在从数据库中查看主从同步状态

show slave status \G;

当Slave_ID_Running: YES 和 Slave_SQLRunning:YES 都为YES 时,说明主从复制已经搭建成功了 其中有个为NO 可以看下方报错日志,查询相关文档进行排错。

测试主从复制

  • 在主容器mysql中创建user表,从容器中user也同步创建了

  • 在主容器user表中插入数据,从容器user数据也跟着插入了

未经允许不得转载:木盒主机 » docker 搭建mysql主从复制

赞 (0)

相关推荐

    暂无内容!