MySQL主从复制做用和原理

1、什么是主从复制?
主从复制,是用来创建一个和主数据库彻底同样的数据库环境,称为从数据库;主数据库通常是准实时的业务数据库。sql


2、主从复制的做用
一、作数据的热备,做为后备数据库,主数据库服务器故障后,可切换到从数据库继续工做,避免数据丢失。
二、架构的扩展。业务量愈来愈大,I/O访问频率太高,单机没法知足,此时作多库的存储,下降磁盘I/O访问的频率,提升单个机器的I/O性能。
三、读写分离,使数据库能支撑更大的并发。在报表中尤为重要。因为部分报表sql语句很是的慢,致使锁表,影响前台服务。若是前台使用master,报表使用slave,那么报表sql将不会形成前台锁,保证了前台速度。数据库


3、主从复制的原理
1.数据库有个bin-log二进制文件,记录了全部sql语句。
2.咱们的目标就是把主数据库的bin-log文件的sql语句复制过来。
3.让其在从数据的relay-log重作日志文件中再执行一次这些sql语句便可。
4.下面的主从配置就是围绕这个原理配置
5.具体须要三个线程来操做:
1.binlog输出线程:每当有从库链接到主库的时候,主库都会建立一个线程而后发送binlog内容到从库。在从库里,当复制开始的时候,从库就会建立两个线程进行处理:
2.从库I/O线程:当START SLAVE语句在从库开始执行以后,从库建立一个I/O线程,该线程链接到主库并请求主库发送binlog里面的更新记录到从库上。从库I/O线程读取主库的binlog输出线程发送的更新并拷贝这些更新到本地文件,其中包括relay log文件。服务器

3.从库的SQL线程:从库建立一个SQL线程,这个线程读取从库I/O线程写到relay log的更新事件并执行。架构

能够知道,对于每个主从复制的链接,都有三个线程。拥有多个从库的主库为每个链接到主库的从库建立一个binlog输出线程,每个从库都有它本身的I/O线程和SQL线程。
主从复制如图:并发

 


原理图2,帮助理解! 性能

 


步骤一:主库db的更新事件(update、insert、delete)被写到binlog
步骤二:从库发起链接,链接到主库
步骤三:此时主库建立一个binlog dump thread线程,把binlog的内容发送到从库
步骤四:从库启动以后,建立一个I/O线程,读取主库传过来的binlog内容并写入到relay log.
步骤五:还会建立一个SQL线程,从relay log里面读取内容,从Exec_Master_Log_Pos位置开始执行读取到的更新事件,将更新内容写入到slave的db.

线程

相关文章
相关标签/搜索