如何实现MySQL Replication 优化

以下的文章主要讨论的是MySQLReplication 优化,我们大家都知道MySQLReplication的实际讨论还是占为大多数的,很多内容的实用性还是很强的,于是就总结了一下,希望会给你带来一些帮助在此方面。

本人英文水平水平有限,难免有翻译的不对的地方,有疑问欢迎讨论:)

 

 

MySQL Replication延时的类型

 

1. 固定性的延时

Slave的数据持续性的落后于Master并且一直无法与Master的数据保持一致。

 

Slave的数据经常在白天落后于Master,而在晚上可以赶上并与Master的记录保持一致。

 

这种类型的延时通常是由于Slave服务器的负载已经到达了上限或在白天访问量大的时候到达上限造成的。

 

2. 非固定性的延时

Slave的数据只是短暂的落后于Master,可在短时间内恢复

 

这类型的延时通常与批量任务和报表有关,效率差的查询也会导致这类延时

 

MySQL Replication的限制

MySQL的Replication是单线程的,意味着只能有效的使用一个CPU内核和一个磁盘,一条复杂的查询或者事务都导致进程被阻塞,不过现在针对5.1版本的多线程Replication补,还是pre版,有很多限制,感兴趣的可以去看看。

Replication的容量

1. 理解什么是Replication的容量

可以将Replication暂停一个小时,重新启动Replication后,观察Slave的数据多久可以与Master一致。从Replication重新启动到和Master数据一致所花费的时间与Replication暂停的时间的比值就是Replication的容量。

 

2. 建议保持Replication的容量在3倍以上,即延迟一个小时的数据,Slave只需要20分钟就能与Master的数据一致。

MySQL Replication的优化

1. 5.0的MySQL中避免类似以下的更新语句

 

  1. INSERT … SELECT <complex query> 
  2. UPDATE .... WHERE <complex clause> 

 

 

复杂的查询会导致Replication线程阻塞。如果是insert或update与select结合的语句,可以讲select单独执行并保存在临时表中,然后再执行insert或者update。

 

如果使用的是5.1的MySQL,新功能中的行级Replication(RBR)可以解决这个问题。RBR可以将在Master上通过复杂查询后更新的结果直接传给Slave,Slave可以直接将结果更新到数据库中。

 

2. 避免大的事务

太大的事务会造成Replication长时间阻塞,数据会严重滞后于Master。

 

Slave服务器的硬件选择

更快的CPU内核,对于单线程的Replication多核CPU是没有任何优势的。

更高速的硬盘,包括更高的转速和更好的高速缓存命中率,如果有钱的话上SSD吧

 

主从结构的扩展性问题

1. 如何降低写操作的频率

Master的写操作会扩散到所有的Slave上,所以高频率的写操作会降低Slave的读操作效率。

 

至少保持一台Slave做全库同步,其他的Slave可以只做部分表的同步。当然,这需要web应用程序的配合来分配哪些查询读哪些Slave。

 

将一些更新操作放到memcached中,例如session和计数器。

 

Slave使用myisam引擎

 

将一些写入量很大的更新操作直接在slave上执行,而不通过Replication。

 

2. 如何更有效的利用Slave的硬件资源

使用分区

 

有选择的对表进行同步

 

在Slave上对数据进行归档。

 

Session的持久化

 

为不同的应用服务器分配不同的Slave进行读操作。

 

或者根据查询类型的不同来分配不同的Slave。

 

3. 如何使你的程序最大化的利用Slave

将对数据更新不敏感的查询放到Slave上,而需要实时数据的查询则放到Master。

 

通过session的持久化,让做了修改的用户首先看到修改的内容,其他的用户可以等待Slave更新后再查看新内容。

 

对于某些数据,可以用memcached来存放数据的版本号,读Slave的程序可以先对比Slave的数据和memcached数据的版本,如果不一致则去读master。用户和博客类的信息可以用这种方法。

 

在查询前可以通过SHOW SLAVE STATUS检测Slave的状态,然后根据返回的结果进行服务器的选择。 以上的相关内容就是对MySQLReplication的介绍,望你能有所收获。

【编辑推荐】

  1. MySQL连接字符串的经验总结
  2. 安装MySQL在linux as3之下
  3. MySQL配置SSL的实际操作流程
  4. MySQL忘记密码的正确解决方法
  5. MySQL 基本命令的用法与注意事项

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/288997.html<

(0)
运维的头像运维
上一篇2025-05-16 14:18
下一篇 2025-05-16 14:19

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注