耶耶耶耶耶 发表于 2024-7-10 20:27:04

MySQL主从同步优化指南:架构、瓶颈与解决方案

前言

​ 在当代数据库架构中,MySQL 主从同步是实现高可用性和负载均衡的关键技术。本文将深入探讨主从同步的架构、耽误缘故因由以及优化策略,并提供专业的监控发起。
MySQL 主从同步架构

​https://img-blog.csdnimg.cn/direct/bbdaad22b8de4103ba8db27d2b27cb76.png
主从复制流程:

[*] 从库生成两个线程,一个 I/O 线程,一个 SQL 线程;
[*] I/O 线程去哀求主库的 binlog,并将得到的 binlog 日志写到 relay log(中继日志) 文件中;
[*] 主库会生成一个 log dump 线程,用来给从库 I/O 线程传 binlog;
[*] SQL 线程会读取 relay log 文件中的日志,并剖析成详细操纵,来实现主从的操纵同等,而最终数据同等;
主从耽误缘故因由


[*]主库写入是并发的,从库 relay log 回放是单线程的,但在 mysql 5.6 版本后提供了 MySQL 的并行复制策略,丁奇的 MySQL 实战45讲有详细介绍
[*]主库有大事件执行,好比一个事件在主库执行10s,从库再回放10s,那么对于当前事件数据主从耽误就是20s
[*]主库或从库 CPU、磁盘IO过高
[*]主库 TPS 过大,从库来不及回放
[*]从库有大量全表扫描查询导致的磁盘IO,笔者曾经就碰到过由于数仓晚上举行从库扫库而导致的20几秒主从耽误

[*]网络题目
[*]主从网络延时过高
[*]主从带宽不敷

[*]服务器硬件性能不敷,如CPU、内存或磁盘性能,会影响复制服从
[*]MySQL设置不合理:如binlog格式、复制方式(异步或半同步)等设置不当大概导致耽误
[*]锁等候:从库上的大型查询语句大概会产生锁等候,影响复制历程
主从耽误优化方案


[*]强制读主:同等性要求高的业务读取主库,其它业务读从库,这个方法在实际开发过程中使用的很多
[*]先读从库,未命中再读主库:适合查询新增的数据,先查询从库,当数据不存在再查询主库,大概会导致会多一次查询从而导致查询时间变长。
[*]分库分表:减少单个主库或从库由于压力过大而导致的耽误
[*]优化网络:确保主从服务器之间有充足的网络带宽和低耽误的毗连
[*]并行复制:在MySQL 5.6及以上版本中,可以开启并行复制功能,允许从服务器并行执行复制的事件。
[*]减少持久化频率:调整 sync_binlog 和 innodb_flush_log_at_trx_commit 参数,以减少每次事件提交时的磁盘同步操纵。
[*]优化查询:确保主服务器上的查询是高效的,减少不必要的复杂查询和大事件。
[*]索引优化:确保从服务器上的索引是最优的,以加快查询速度。
[*]使用SSD:相比传统硬盘,SSD有更快的读写速度,可以减少I/O瓶颈。
监控与维护

​ 有效的监控是确保主从同步康健运行的关键。使用专业的监控工具,如 Percona Toolkit,可以帮助我们实时监控复制状态,及时发现并解决耽误题目。
Reference


[*]腾讯云开发者社区 - MySQL主从同步原理和应用
[*]掘金 - 看完这篇还不懂 MySQL 主从复制
[*]Zq99299 的技术博客 - 主从复制状态机与所有分布式存储都是这么复制数据的
[*]Worktile MySQL主从耽误题目怎么解决
[*]掘金:美团面试被问到主从耽误的解决办法

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: MySQL主从同步优化指南:架构、瓶颈与解决方案