MySQL表名映射方案及扩展应用_MySQL

这篇文章介绍的简单方案应用于以下需求:主库为了性能考虑,做分库分表,从库则上为了多索引查询等需求,不做分表。ide

参数replicate-rewrite-db 及应用性能

       这个参数是官方版本自带的。配置格式为 replicate-rewrite-db = from_db -> to_db。 同步效果为将全部在from_db上的操做都修改成对to_db的操做。spa

         例子:.net

       所以能够在主库上作分库,如须要将表abc分红10个,则主库上建10个db, 名字为sdb_1, sdb_2, … , sbd_10, 从库上则只有一个库sdb.orm

       在从库my.cnf中配置10行,第一行为replicate-rewrite-db = sdb_1 -> sdb,以此类推。server


存在的问题索引

       这个参数可以解决一部分问题,可是对于单库内的分表则没法解决。并且若分库多了,好比须要创建1024个库,一来维护麻烦,二来my.cnf里面配置好长.get

       还有一个很要命的问题是,对于有些应用是按照时间分表,好比按月份新增表,若用此方法新增库,修改my.cnf则还须要重启slave。同步

       另外,并非全部的表都须要分表,库级别的映射方案也有诸多不便。it


参数replicate-wild-rewrite-table

       这个新增的参数目的就是要解决上面说到的问题。配置格式以下:

replicate-wild-rewrite-table=sdb.abc_% -> sdb.abc.

       从库上同步效果为,将sbd库内全部符合abc_%格式的表的DML操做,都执行到 sdb.abc表中。


几点说明

一、  这个patch(代码)基于Percona Server 5.5.18 (淘宝MySQL分支目前基于这个版本)

二、  只对row based replication的有效

三、  只对dml有效

相关文章
相关标签/搜索