热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

mysql缩容_MySQL分布式架构扩缩容的初步设计

MySQL分布式架构扩缩容的初步设计MySQL分布式架构的扩缩容是一个很有意思的话题.严格的说,我们所说的这种架构方案是一种伪分布式架构,我们就做下统称.重点是扩缩容的思路上.如果

MySQL 分布式架构扩缩容的初步设计

MySQL 分布式架构的扩缩容是一个很有意思的话题. 严格的说, 我们所说的这种架构方案是一种伪分布式架构, 我们就做下统称. 重点是扩缩容的思路上.

如果一套环境的主从完整, 分为多个逻辑分片的情况下, 大体是这样的架构.

这个架构采用了 4 个物理分片, 每个物理分片上有 4 个逻辑分片, 总共有 16 个逻辑分片, 也就意味着一张表被分为了 16 份.

ab7653affab982b574eb7acc55df2e04.gif

对于扩容来说, 是优先考虑主库写入为主, 所以我们的扩容可以是 2N 的规模来扩容, 比如 4 个物理分片, 可以扩容为 8 个物理分片, 大体的架构和分布如下, 这个时候从库顶上来做了主库.

ab7653affab982b574eb7acc55df2e04.gif

从扩容的角度来说, 这也就是我们预期要做的事情, 4 个变 8 个, 8 个变 16 个. 一套环境按照设定的分片规模可以扩容两次.

而缩容怎么来做呢, 我们需要考虑得更细致一些, 所以我就截取了物理分片 1 的一个相对详细的数据复制关系图.

扩容前, 分片节点上的 4 个逻辑分片都是 active 状态, 都可以写入数据, 从库是 inactive, 只负责数据同步.

ab7653affab982b574eb7acc55df2e04.gif

扩容后, 原本的 db1,db2 为 active 状态, 而 db3,db4 在原来的 Slave 节点上是 active 状态

ab7653affab982b574eb7acc55df2e04.gif

这个基础上, 我们需要保证的就是将原本隔离的节点数据统一为 Master 端 active 状态. 这个过程说起来容易, 操作起来就是一个难点了.

ab7653affab982b574eb7acc55df2e04.gif

这个事情如果相对平滑的完成, 其实整个分布式集群的管理就不在话下了.

来源: http://database.51cto.com/art/201812/588219.htm



推荐阅读
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • t-io 2.0.0发布-法网天眼第一版的回顾和更新说明
    本文回顾了t-io 1.x版本的工程结构和性能数据,并介绍了t-io在码云上的成绩和用户反馈。同时,还提到了@openSeLi同学发布的t-io 30W长连接并发压力测试报告。最后,详细介绍了t-io 2.0.0版本的更新内容,包括更简洁的使用方式和内置的httpsession功能。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • 解决VS写C#项目导入MySQL数据源报错“You have a usable connection already”问题的正确方法
    本文介绍了在VS写C#项目导入MySQL数据源时出现报错“You have a usable connection already”的问题,并给出了正确的解决方法。详细描述了问题的出现情况和报错信息,并提供了解决该问题的步骤和注意事项。 ... [详细]
  • 本文详细介绍了MySQL表分区的创建、增加和删除方法,包括查看分区数据量和全库数据量的方法。欢迎大家阅读并给予点评。 ... [详细]
  • 本文介绍了将mysql从5.6.15升级到5.7.15的详细步骤,包括关闭访问、备份旧库、备份权限、配置文件备份、关闭旧数据库、安装二进制、替换配置文件以及启动新数据库等操作。 ... [详细]
  • MongoDB用户验证auth的权限设置及角色说明
    本文介绍了MongoDB用户验证auth的权限设置,包括readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase、cluster相关的权限以及root权限等角色的说明和使用方法。 ... [详细]
  • 一句话解决高并发的核心原则
    本文介绍了解决高并发的核心原则,即将用户访问请求尽量往前推,避免访问CDN、静态服务器、动态服务器、数据库和存储,从而实现高性能、高并发、高可扩展的网站架构。同时提到了Google的成功案例,以及适用于千万级别PV站和亿级PV网站的架构层次。 ... [详细]
  • PDO MySQL
    PDOMySQL如果文章有成千上万篇,该怎样保存?数据保存有多种方式,比如单机文件、单机数据库(SQLite)、网络数据库(MySQL、MariaDB)等等。根据项目来选择,做We ... [详细]
  • 推荐一个ASP的内容管理框架(ASP Nuke)的优势和适用场景
    本文推荐了一个ASP的内容管理框架ASP Nuke,并介绍了其主要功能和特点。ASP Nuke支持文章新闻管理、投票、论坛等主要内容,并可以自定义模块。最新版本为0.8,虽然目前仍处于Alpha状态,但作者表示会继续更新完善。文章还分析了使用ASP的原因,包括ASP相对较小、易于部署和较简单等优势,适用于建立门户、网站的组织和小公司等场景。 ... [详细]
  • Elasticsearch1Elasticsearch入门1.1Elasticsearch术语1.1.16.0以前的Elasticsearch术语1.1.26.0以后的Elasti ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • 本文介绍了OpenStack的逻辑概念以及其构成简介,包括了软件开源项目、基础设施资源管理平台、三大核心组件等内容。同时还介绍了Horizon(UI模块)等相关信息。 ... [详细]
  • Python开源库和第三方包的常用框架及库
    本文介绍了Python开源库和第三方包中常用的框架和库,包括Django、CubicWeb等。同时还整理了GitHub中最受欢迎的15个Python开源框架,涵盖了事件I/O、OLAP、Web开发、高性能网络通信、测试和爬虫等领域。 ... [详细]
author-avatar
小遥2502881765
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有