Docker容器技术–安装MySQL主从复制
概念及原理
什么是主从复制
主从复制(Master-Slave Replication)是MySQL数据库提供的一种数据同步技术,它允许数据从一个MySQL数据库服务器(主服务器或Master)复制到一个或多个MySQL数据库服务器(从服务器或Slave)。这种复制功能通常用于备份、故障恢复、读取扩展以及数据分析等场景。
- 主服务器
- 负责处理写操作(INSERT、UPDATE、DELETE等)。
- 当数据发生变化时,会将这些变化记录到二进制日志(Binary Log)中。
- 从服务器
- 负责处理读操作,可以分担主服务器的读取负载。
- 通过I/O线程从主服务器读取二进制日志中的事件,并将这些事件写入到从服务器的中继日志(Relay Log)中。
- 从服务器的SQL线程读取中继日志中的事件,并执行这些事件,从而更新从服务器的数据。
主从复制的工作流程
- 主服务器上的写操作被记录到二进制日志中。
- 从服务器的I/O线程连接到主服务器,读取二进制日志中的事件,并将这些事件写入到中继日志中。
- 从服务器的SQL线程读取中继日志中的事件,并执行这些事件,更新从服务器的数据。
主从复制的优点
- 数据备份:从服务器可以作为主服务器的备份,防止数据丢失。
- 故障恢复:如果主服务器出现故障,可以迅速将其中一个从服务器提升为主服务器,继续提供服务。
- 读取扩展:通过将从服务器用于读取操作,可以分担主服务器的读取负载,提高系统的吞吐量和响应速度。
- 数据分析:可以在从服务器上运行数据分析任务,而不会影响到主服务器的性能。
注意事项
- 主从复制是异步的,从服务器的数据可能会稍微落后于主服务器。
- 主从复制不是完全的高可用性解决方案,还需要其他技术(如负载均衡、故障切换等)来确保服务的连续性。
- 在配置和使用主从复制时,需要注意网络延迟、数据一致性、复制延迟等问题。
安装操作
- 新建主服务器实例
暴露端口3307docker run -p 3307:3306 --name=mysql-master \ -v /root/mysql-master/log:/var/log/mysql \ -v /root/mysql-master/data:/var/lib/mysql \ -v /root/mysql-master/conf:/etc/mysql \ -e MYSQL_ROOT_PASSWORD=root \ -d mysql:5.7
- 进入 /root/mysql-master/conf 目录下新建配置文件 my.cnf
vim my.cnf
[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
- 重启并进入mysql-master实例
docker restart mysql-master docker exec -it mysql-master /bin/bash
- 进入mysql-master实例内数据库,创建数据同步用户
mysql -uroot -proot create user ‘slave’@’%’ identified by ‘123456’; grant replication slave,replication client on *.* to 'slave'@'%';
- 新建从服务器实例
暴露端口3308docker run -p 3308:3306 --name=mysql-slave \ -v /root/mysql-slave/log:/var/log/mysql \ -v /root/mysql-slave/data:/var/lib/mysql \ -v /root/mysql-slave/conf:/etc/mysql \ -e MYSQL_ROOT_PASSWORD=root \ -d mysql:5.7
- 进入 /root/mysql-slave/conf 目录下新建配置文件 my.cnf
vim my.cnf
[mysqld] ##设置server_id,同一局域网中需要唯一 server_id=102 ##指定不需要同步的数据库名称 binlog-ignore-db=mysql ##开启二进制日志功能,以备slave作为其他数据库实例的master时使用 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 ##relay_log配置中继日志 relay_log=mall-mysql-relay-bin ##log_slave_updates表示slave将复制事件写进自己的二进制日志 log_slave_updates=1 ##slave设置为只读(具有super权限的用户除外) read_only=1
- 重启mysql-slave实例
docker restart mysql-slave
- 在主数据库中查看主从同步状态
shou master status;
- 进入mysql-slave实例数据库
配置主从复制docker exec -it mysql-slave /bin/bash mysql -uroot -proot
change master to master_host='192.168.1.8', master_user='slave', master_password='123456',master_port=3307,master_log_file='mall-mysql-bin.000001', master_log_pos=617, master_connect_retry=30;
- 在从数据库中开启主从复制
start slave;
- 在从数据库中查看主从同步状态
show slave status\G;