用federated引擎在不同服务器间转移mysql表(转载)

用federated引擎在不同服务器间转移mysql表

假设一个场景:在某一天,我需要将my01上的某些表转移到另一台机器my02上,都有哪些方法可以实现?至于转移的目的可能有很多,比如my01磁盘不够了,我对DB进行拆分;比如用性能更好(差)的my02代替my01;比如线上环境与线下环境进行数据备份….

针对这个问题,你肯定会马上想出下面的方法:

 

  1. 从my01上SELECT出来,保存到一个文本文件里,再INSERT到my02上去;
  2. 如果是myisam表,直接从my01将文件scp到my02上去;

第一种方法可行,但是存在两次数据落地(my01->本地磁盘,本地磁盘->my02),并且在转移过程中,存在字符转义(不可见字符)的情况,可能导致数据不一致情况出现。

第二种方法再好不过了,但假如这个转移表的需求是一个日常的工作,生产环境的mysql服务器出于安全考虑又不允许我们scp,或者这个表不是myisam的,那就行不通了。

那么,我们用federated表来试试吧。你应该想到了,我是这么做的:

  1. 在my02上建立一个federated表,connection指向my01的待转移表;
  2. 在my02上执行下列SQL:
    INSERT INTO 新表 SELECT * FROM federated表
  3. 在my02上DROP掉federated表,至此,工作完成。

不过,mysql在编译安装时默认并没有包含federated引擎,并且即使安装了,启动mysql服务的时候也需要额外增加参数才能使用federated表。我相信很少有生产环境满足这两个条件。不过,为了用得爽,做一些改变又何乐而不为呢?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值