1什么会增长主从延迟?
1 网络很差
2 从库硬件差
3 索引没作好,从库执行慢
4 从库锁等待,多见于myisam
5 主库写频繁,从库单线程执行慢
6 使用row复制,或mix使用行复制mysql
2如何优化,减小延迟时间?
1 如何写频繁,水平拆分,减小单片写数量
2 避免复杂DML操做sql
3几个由于主从延迟发送异常的场景
1 一个事务内有读和写操做
2 修改后紧接着接口访问数据库
4业务上如何解决主从延迟?
解决这个问题有如下几个思路:缓存
1. 流程优化避免写后当即读取
a 业务流程上:写完成后接口返回,客户端再次调用接口获取数据,在这个过程当中同步已经完成;
b 代码上:写完成后缓存结果到局部变量,内存或缓存中,下次读取直接走缓存;
2. 避免主从延迟,保证读写强一致性
a 若是是一主一从,能够使用数据库提供的半同步复制,写完成时会等待从库同步完成后返回;可是强一致性会下降写吞吐量
b mysql5.6之后能够使用semi-sync功能,实现强一致性;
c 线上读写都是使用主库,从库只作线下运营,分析使用;为了缓解数据库读写压力,在数据库上架构缓冲层;
3. 强制读走主库
4. 配置经验延迟时间,延迟时间范围内的查询走主库;
a 中间件实现。不少中间件提供这种配置
b 应用层实现。架构一个缓存层,对数据修改后将key保存在cache总,设置生存时间为经验延迟时间。查询时首先查询cache,若是找到key则强制走主库;
另外,经过show slave status 字段‘Second_Behind_Master’能够检测主从延迟时间,在延迟较大时,将读切到读库,若是是使用中间件,能够配置强制读主库的延迟:slaveThreshold;这种方式不能保证读到脏数据,对一致性要求不高时能够使用;网络
















