主从复制概述
- 主从复制是指将主数据库的 DDL 和 DML 操作通过二进制日志传到从库服务器中,然后在从库上对这些日志重新执行(也叫重做),从而使得从库和主库的数据保持同步。
- MySQL支持一台主库同时向多台从库进行复制, 从库同时也可以作为其他从服务器的主库,实现链状复制。
- MySQL 复制的优点主要包含以下三个方面:
- 主库出现问题,可以快速切换到从库提供服务。
- 实现读写分离,降低主库的访问压力。
- 可以在从库中执行备份,以避免备份期间影响主库服务。
主从复制原理
-
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
[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
修改从容器配置
- 进入从容器
sudo docker exec -it slave_mysql bin/bash
- 更新软件
apt-get update
- 下载vim编辑器
apt-get vim
- 修改从容器mysql配置文件
vim /etc/mysql/my.cof
[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
重启主容器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;
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 连接主容器的次数
- 启动slave
start slave
- 在从数据库中查看主从同步状态
show slave status \G;
当Slave_ID_Running: YES 和 Slave_SQLRunning:YES 都为YES 时,说明主从复制已经搭建成功了 其中有个为NO 可以看下方报错日志,查询相关文档进行排错。
测试主从复制
- 在主容器mysql中创建user表,从容器中user也同步创建了
- 在主容器user表中插入数据,从容器user数据也跟着插入了
评论