主从复制:
将主数据库中的DDL和DML操作通过二进制日志(BINLOG)传输到从数据库上,然后将这些日志重新执行(重做);从而使得从数据库的数据与主数据库保持一致。
主从复制的作用
1、 主数据库出现问题,可以切换到从数据库。
2、 可以进行数据库层面的读写分离。
3、 可以在从数据库上进行日常备份。
MySQL主从复制解决的问题
1、数据分布:随意开始或停止复制,并在不同地理位置分布数据备份
2、 负载均衡:降低单个服务器的压力
3、 高可用和故障切换:帮助应用程序避免单点失败
4、 升级测试:可以用更高版本的MySQL作为从库
MySQL主从复制工作原理
1、 在主库上把数据更高记录到二进制日志
2、 从库将主库的日志复制到自己的中继日志
3、 从库读取中继日志的事件,将其重放到从库数据中
基本原理流程,3个线程以及之间的关联
主:binlog线程一一记录下所有改变了数据库数据的语句,放进master上的binlog中;
从:io线程在使用start slave之后,负责从master上拉取binlog内容,放进自己的relay log 中;
从:sql执行线程执行relay log中的语句;
Binary log:主数据库的二进制日志
Relay log:从服务器的中继日志
1、 master在每个事务更新数据完成之前,将该操作记录串行地写入到binlog文件中。
2、 salve开启一个I/O Thread,该线程在master打开一个普通连接,主要工作是binlog dump process。如果读取的进度已经跟上了 master,就进入睡眠状态并等待master产生新的事件。I/O线程最终的目的是将这些事件写入到中继日志中。
3、 SQL Thread会读取中继日志,并顺序执行该日志中的SQL事件,从而与主数据库中的数据保持一致。
Was this helpful?
0 / 0