Home  >  Article  >  Database  >  用户信息表水平拆表方案

用户信息表水平拆表方案

WBOY
WBOYOriginal
2016-06-07 17:41:431306browse

下面方法就是利用用户ID进行取模,MOD(new.id,3),3就代表拆分到3张表里。以下是步骤:第一步、在主库上(M)建立拆分的三张表,t0,t1,t2createtablet0liket;creat

下面

方法就是利用用户ID进行取模,MOD(new.id,3),3就代表拆分到3张表里。

以下是步骤:

第一步、在主库上(M)建立拆分的三张表,t0,t1,t2

第二步、在主库上(M)建立三个触发器(插入、更新、删除)

这样t表数据变更时,就会按照取模的结果更新到t0,t1,t2这三张表里

第三步、确保同步复制延时为0时,在从库上(S)stop slave关闭同步复制,并show slave status\G记录到文本里,以便后面时用到。

第四步、在从库上新建一个实例(S2),并导出t,t0,t1,t2四张表(导出时只要数据,不要表结构)

  • --dump-slave是MySQL5.5的一个特性,香港空间,具体你可参考我这一篇文章

    如果你是5.1的,就要用到第三步我们记录的show slave status\G到文本,找到change master to的那个点,这样就保证了拆分后的增量数据。

    第五步,在从库上S2实例上,创建表t,t0,t1,t2,也同样建立那三个触发器,这样做的目的是,当我们导入的时候,就会通过触发器取模,把数据分散到t0,t1,t2这三张表里,然后开启同步复制主库M。

    第六步,上面五步做完以后,香港服务器,请检查下数据的增长情况,并观察同步是否正常,都没问题的话,就可以把数据分散到新的3台服务器里。

    在S2实例上,把t0表dump出来并导入到M_new1机器上,然后在M_new1机器上,在my.cnf里增加

  • 忽略t1,t2表的同步复制。

    把t1表dump出来并导入到M_new2机器上,然后在M_new2机器上,在my.cnf里增加

  • 忽略t0,t2表的同步复制。

    把t2表dump出来并导入到M_new3机器上,然后在M_new3机器上,在my.cnf里增加

  • 忽略t0,t1表的同步复制。

    第七步,美国服务器,到目前为止,基本上我们已经做完了,剩下的就要开发改他们的代码,告诉他们拆分的规则,按用户ID取模,拆分几个表,拆分到哪台机器上,IP是什么。

    等凌晨0:00点,开发让运维重启前端应用,这样就顺利实现了用户信息表的拆分。

    过程可能有些复杂,有兴趣的朋友,可以按照我上面的操作,做下测试。

     

    本文出自 “贺春旸的技术专栏” 博客,请务必保留此出处

  • Statement:
    The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn