这篇文章介绍的简单方案应用于如下需求:主库为了性能考虑,作分库分表,从库则上为了多索引查询等需求,不作分表。
参数replicate-rewrite-db 及应用
这个参数是官方版本自带的。配置格式为 replicate-rewrite-db = from_db -> to_db。 同步效果为将所有在from_db上的操作都修改为对to_db的操作。
例子:
因此可以在主库上做分库,如需要将表abc分成10个,则主库上建10个db, 名字为sdb_1, sdb_2, … , sbd_10, 从库上则只有一个库sdb.
在从库my.cnf中配置10行,第一行为replicate-rewrite-db = sdb_1 -> sdb,以此类推。
存在的问题
这个参数能够解决一部分问题,但是对于单库内的分表则无法解决。而且若分库多了,比如需要建立1024个库,一来维护麻烦,二来my.cnf里面配置好长.
还有一个很要命的问题是,对于有些应用是按照时间分表,比如按月份新增表,若用此方法新增库,修改my.cnf则还需要重启slave。
另外,并不是所有的表都需要分表,库级别的映射方案也有诸多不便。
参数replicate-wild-rewrite-table
这个新增的参数目的就是要解决上面说到的问题。配置格式如下:
replicate-wild-rewrite-table=sdb.abc_% -> sdb.abc.
从库上同步效果为,将sbd库内所有符合abc_%格式的表的DML操作,都执行到 sdb.abc表中。
几点说明
1、 这个patch (代码) 基于Percona Server 5.5.18 (淘宝MySQL分支目前基于这个版本)
2、 只对row based replication的有效(多表更新的SQL改写问题)
3、 只对dml有效(细想一下就知道,ddl不能支持)
4、 结合多主复制 http://t.cn/zWwSFhM ,则整个方案能将分库分表的都同步到slave的同一个表上
分享到:
相关推荐
MySql表名大小写的问题.txt
使用原生jdbc连接mysql数据库,获取所有表名,并映射成java实体类,支持spring注解。摆脱繁琐的实体类编写工作。
CentOS8部署Mysql NDB Cluster8+Mysql Router8方案及应用~~~~
易语言MYSQL取表名源码,MYSQL取表名
mysql.zip docker 安装mysql的映射文件
MYSQL数据库取表名易语言源码。@易语言数据库教程。
linux下mysql默认是要区分表名大小写的。mysql是否区分大小写设置是由参数lower_case_table_names决定的,其中: 1)lower_case_table_names = 0 区分大小写(即对大小写不敏感),默认是这种设置。这样设置后,...
mysql备份和恢复方案mysql备份和恢复方案mysql备份和恢复方案mysql备份和恢复方案mysql备份和恢复方案mysql备份和恢复方案mysql备份和恢复方案mysql备份和恢复方案mysql备份和恢复方案mysql备份和恢复方案mysql备份...
es-mysql数据映射sql编写
MySQL数据库原理及应用(第2版)(微课版)-课外拓展.pdfMySQL数据库原理及应用(第2版)(微课版)-课外拓展.pdfMySQL数据库原理及应用(第2版)(微课版)-课外拓展.pdfMySQL数据库原理及应用(第2版)(微课版)-课外拓展....
易语言MYSQL取表名源码
易语言源码易语言MYSQL取表名源码.rar
今天郁闷死了,在LINUX下调一个程序老说找不到表,但是我明明是建了表的,在MYSQL的命令行下也可以查到,为什么程序就找不到表呢?
文件包含一个工具类,是mysql数据库表生成实体工具类,压缩文件中有相关jar包。目前符合我的日常需要,有缺陷的地方大家一起补充.....欢迎留言,谢谢
《MySQL数据库原理及应用》的教案,包含所有章节。。。
Lvs+Keepalived+MySQL 单点写入主主同步高可用方案 Lvs+Keepalived+MySQL 单点写入读负载均衡主主同步高可用方案 Heartbeat高可用MySQL主主同步方案 Heartbeat+DRBD+MySQL高可用方案 MMM高可用MySQL方案
mybatis 生成mysql对应映射文件