V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
puritania
V2EX  ›  问与答

mysql 数据库分片后如何平滑扩容?

  •  
  •   puritania · 2019-02-23 22:40:52 +08:00 · 2071 次点击
    这是一个创建于 2102 天前的主题,其中的信息可能已经有所发展或是发生改变。

    当前数据库分片数据量已成为瓶颈,如何平滑扩容?

    5 条回复    2019-02-24 00:05:31 +08:00
    lincanbin
        1
    lincanbin  
       2019-02-23 22:41:57 +08:00 via Android
    平滑是指不停机吗?
    puritania
        2
    puritania  
    OP
       2019-02-23 23:04:19 +08:00   ❤️ 1
    @lincanbin 是的,想在增加几台数据库,原来是用 hash 取模做的映射。
    zhchyu999
        3
    zhchyu999  
       2019-02-23 23:05:19 +08:00
    试试 TiDB
    lincanbin
        4
    lincanbin  
       2019-02-23 23:26:05 +08:00 via Android
    不停机的话,你只能把这个分片的逻辑单独抽出来做一个数据库中间件,这样以后好扩展。
    数据库中间件里,扩容时迁移&双写数据到新的 bucket,然后检验到一致的瞬间 stop the world,把所有连接迁移到新的扩容后的数据库上。

    反正是很麻烦,不知道有没有现成的开源实现。
    hilbertz
        5
    hilbertz  
       2019-02-24 00:05:31 +08:00
    主从同步后,交换主从
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1058 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 19:55 · PVG 03:55 · LAX 11:55 · JFK 14:55
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.