Mysql主从复制和读写分离 原理
为什么需要主从复制?
1.试想在一个复杂的业务系统中,有一个场景 有一句sql需要锁表 导致暂时不能使用读的服务,那么就很影响运行中的业务,使用主从复制,让主库负责写,从库负责读,这样及时主库出现了锁表的情景,通过读从库也能保证业务的正常运作。
2.做数据的热备
3.业务量变大 单机无法满足做集群 做多库存储 降低磁盘IO
什么是mysql的主从复制?
Mysql主从复制是指数据可以从一个Mysql数据库服务器主节点复制到一个或者是多个从结点。Mysql默认采用异步复制方式,这样从结点不用一直访问主服务器来更新自己的数据,数据的更新可以在远程连接上进行,从结点可以复制主数据库中的所有数据库或者特定数据库 或者特定的表
复制原理
1.master服务器将数据的改变记录在binlog日志上面,当master上的数据发生改变时候 将其改变写入日志
2.slave服务器会在一定时间间隔内对master的日志进行扫描检查其是否发生了改变 如果发生了改变 则开始一个IO线程请求master二进制事件
3.同时master结点为每个IO线程启动一个dump线程 用于向其发送二进制事件,并保存至从结点中继日志中,从结点启动sql线程从中继日志中读取 在本地重放 使得数据和主节点保持一致 IO线程和sql线程进入睡眠状态 等待下一次被唤醒。
各种架构:
主从 主主 一主多从 多主一从 联级复制:一主一从多从(一般是用来做好数据的备份)
读写分离
Mysql读写分离基本原理是让master数据库处理写操作,slave数据库处理读操作.master将写操作同步到各个slave结点