码迷,mamicode.com
首页 > 数据库 > 详细

mysql扩展性架构实践N库到2N 库的扩容,2变4、4变8

时间:2017-12-05 01:01:09      阅读:277      评论:0      收藏:0      [点我收藏+]

标签:服务   www   58同城   架构设计   bsp   分享图片   提升   方式   架构师   

mysql扩展性架构实践N库到2N 库的扩容,2变4、4变8

http://geek.csdn.net/news/detail/52070
58同城 沈剑

 

http://www.99cankao.com/algebra/modulo-calculator.php

取模计算器

 


扩展性也是架构师在做数据库架构设计的时候需要考虑的一点。首先分享一个58同城非常帅气的秒级数据扩容的方案。这个方案解决什么问题呢?原来数据库水平切分成N个库,现在要扩容成2N个库,解决的就是这个问题。

一开始除以2取模 0或者1

技术分享图片

假设原来分成两个库,假设按照hash的方式分片。如上图,分为奇数库和偶数库。

技术分享图片

第一个步骤提升从库,底下一个从库放到上面来(其实什么动作都没有做);
第二个步骤修改配置此时扩容完成,原来是2个分片,修改配置后变成4个分片,这个过程没有数据的迁移。原来偶数的那一部分现在变成了两个部分,一部分是0,一部分是2,奇数的部分现在变成1和3。0库和2库没有数据冲突,只是扩容之后在短时间内双主的可用性这个特性丢失掉了。

扩展之后除以4取模 ,0,1,2,3

技术分享图片

第三个步骤还要做一些收尾操作:把旧的双主给解除掉,为了保证可用性增加新的双主同步,原来拥有全部的数据,现在只为一半的数据提供服务了,我们把多余的数据删除掉,结尾这三个步骤可以事后慢慢操作。整个扩容在过程在第二步提升从库,修改配置其实就秒级完成了,非常的帅气。

这个方案的缺点是只能实现N库到2N 库的扩容,2变4、4变8,不能实现2库变3库,2库变5库的扩容。

 

 

f

mysql扩展性架构实践N库到2N 库的扩容,2变4、4变8

标签:服务   www   58同城   架构设计   bsp   分享图片   提升   方式   架构师   

原文地址:http://www.cnblogs.com/MYSQLZOUQI/p/7979642.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!