MYSQL——主从复制的原理及实验步骤
文章目录
一、什么是mysql的主从复制?
主从复制,是指使用两个或两个以上的相同数据,其中一个当主数据库(master),而另一个当从数据库(slave)。而在主数据库上进行的所有操作,从数据库都会一一记录,达到两者一模一样。
二、mysql主从复制的原理
1.主从复制原理图
2.主从复制原理描述
1、主服务器MySQL服务将所有的写操作记录在binlog日志中,并生成log dump线程,将binlog日志传给从服务器MySQL服务的I/O线程。
2、从服务器MySQL服务生成两个线程,-个是I/O线程,另一个是SQL线程。
3、从库I/O线程去请求主库的binlog日志,并将binlog日志中的文件写入relaylog (中继日志)中。
4、从库的SQL线程会读取relaylog中的内容,并解析成具体的操作,来实现主从的操作一致, 达到最终两个数据库数据一致的目的。
三、mysql主从复制项目的步骤
1.项目环境准备
准备2台2c/4G的服务器(虚拟机),安装相同版本的虚拟机(建议centos7.6),安装部署好mysql 5.7.33
2.实验步骤
黑底图片为master上的操作,白底图片为slave上操作
1.准备好2台安装好系统的机器,使用脚本一键部署好二进制版本的MySQL,并且设置好my.cnf配置文件的内容。
2.在master服务器上开启二进制日志和配置server_id,从服务器上配置server_id
3.在master上创建给slave过来复制二进制日志的用户
4.在master上做一个全备,导出数据导入到slave上,保持master和slave上的数据一致
5.在slave上配置去master上拉取二进制日志的用户名和密码以及日志文件的名称和位置号等信息
查看位置号和端口号
配置slave
6.在master和slave都关闭防火墙和selinux
此时 Slave_IO_Running: No
Slave_SQL_Running: No
7.在slave服务器上启动 slave服务,查看IO线程和SQL线程是否正常启动
start slave;
重复上述操作,可以看到:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
8.验证主从复制的效果
四、mysql的主从复制作用?
1、做数据的热备,作为后备数据库,主数据库服务器故障后,可切换到从数据库继续工作,避免数据丢失。
2、架构的扩展。业务量越来越大,I/O访问频率过高,单机无法满足,此时做多库的存储,降低磁盘I/O访问的频率,提高单个机器的I/O性能。
3、读写分离,使数据库能支撑更大的并发。在报表中尤其重要。由于部分报表sql语句非常的慢,导致锁表,影响前台服务。如果前台使用master,报表使用slave,那么报表sql将不会造成前台锁,保证了前台速度。