MySQL复制与读写分离
MySQL的复制架构就是以一台服务器充当主服务器,而一台或多台其它服务器充当从服务器。从服务器基于主服务器的二进制日志跟踪所有对数据库的更改操作,以而在从服务器上的数据拷贝执行相同的更改操作。使用MySQL复制架构可以通过在主服务器和从服务器之间分离客户处理负荷,从而得到更好的客户响应时间。使用复制的另一个好处是可以使用一个从服务器执行备份,而不会干扰主服务器。因而,MySQL复制架构主要应用于:分布数据、负载平衡(load balancing)、备份或其他高可用性(high availability)和容错的架构中。 大体上,复制有3个步骤: 1.主服务器把数据更改记录到二进制日志中(二进制日志事件Binary Log Events) 2.从服务器把主服务器的二进制日志事件拷贝到自己的中继日志(Relay Log)中。 3.从服务器重放中继日志中的事件,把更改应用到自己的数据上。 该过程的第一部分就是主服务器记录二进制日志。在每个事务更新数据完成之前,主服务器在二日志记录这些改变。MySQL将事务串行的写入二进制日志,即使事务中的语句都是交叉执行的。在事件写入二进制日志完成后,主服务器通知存储引擎提交事务。 下一步就是从服务器将主服务器的binary log拷贝到它自己的中继日志。首先,从服务器开始一个工作线程——I/O线程。I/O线程在主服务器上打开一个普通的连接