主从复制概述
- 主从复制是指将主数据库的 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
<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主从复制