开发者社区> zhangshengdong> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

【转】MySQL数据库复制表名映射方案及扩展应用

简介: 转自:http://www.mysqlops.com/2012/06/20/mysql%E8%A1%A8%E5%90%8D%E6%98%A0%E5%B0%84%E6%96%B9%E6%A1%88%E5%8F%8A%E6%89%A9%E5%B1%95%E5%BA%94%E7%94%A8.html这篇文章介绍的简单方案应用于如下需求:主库为了性能考虑,作分库分表,从库则上为了多索引查询等需求,不作分表。
+关注继续查看
转自:http://www.mysqlops.com/2012/06/20/mysql%E8%A1%A8%E5%90%8D%E6%98%A0%E5%B0%84%E6%96%B9%E6%A1%88%E5%8F%8A%E6%89%A9%E5%B1%95%E5%BA%94%E7%94%A8.html

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

参数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不能支持)


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
系统已有MYSQL环境,如何安装宝塔面板
最近一直想搞一个在线博客网站,把代码部署到服务器。 下载己经下载了宝塔的.exe文件,安装提示系统已经存在MYSQL环境,请用纯净系统安装。
0 0
Centos安装MySQL详细步骤
Centos安装MySQL详细步骤
0 0
Docker安装MySQL|学习笔记
快速学习Docker安装MySQL
0 0
MySQL 安装和基本操作| 学习笔记
快速学习 MySQL 安装和基本操作
0 0
MySQL_01:MySQL的安装、下载、卸载、配置、登录
MySQL_01:MySQL的安装、下载、卸载、配置、登录
0 0
04_mysql安装 Docker安装mysql
简单实用Docker安装部署mysql github:https://github.com/qq153916230/study.git
0 0
安装MySQL时报由于找不到VCRUNTIME140_1.dll,无法继续执行代码。重新安装程序可能会解决此问题错误
安装MySQL时报由于找不到VCRUNTIME140_1.dll,无法继续执行代码。重新安装程序可能会解决此问题错误
0 0
【Linux】【开发环境】【RHEL】开发环境搭建系列之七——安装基础MySQL环境
【Linux】【开发环境】【RHEL】开发环境搭建系列之七——安装基础MySQL环境
0 0
Docker安装Mysql,Redis,ElasticSearch
Docker安装Mysql,Redis,ElasticSearch
0 0
1:安装、连接以及配置-MySQL
1:安装、连接以及配置-MySQL
0 0
+关注
zhangshengdong
文为世范,行为士则
文章
问答
文章排行榜
最热
最新
相关电子书
更多
MySQL表和索引优化实战
立即下载
One Box: 解读事务与分析一体化数据库 HybridDB for MySQL
立即下载
One Box:解读事务与分析一体化数据库HybridDB for MySQL
立即下载