如何将mysql的一个完整数据库全部复制到另外一个数据库?如果从库上表 t 数据与主库不一致怎么把mysql的库复制,导致复制错误 , 整个库的数据量很大 , 重做从库很慢,如何单独恢复这张表的数据?通常认为是不能修复单表数据的 , 因为涉及到各表状态不一致的问题 。下面就列举备份单表恢复到从库会面临的问题以及解决办法怎么把mysql的库复制:
场景 1
如果复制报错后,没有使用跳过错误、复制过滤等方法修复主从复制 。主库数据一直在更新,从库数据停滞在报错状态(假设 GTID 为 aaaa:1-100) 。
修复步骤怎么把mysql的库复制:
在主库上备份表 t (假设备份快照 GTID 为 aaaa:1-10000);
恢复到从库;
启动复制 。
这里的问题是复制起始位点是 aaaa:101,从库上表 t 的数据状态是领先其怎么把mysql的库复制他表的 。aaaa:101-10000 这些事务中只要有修改表 t 数据的事务,就会导致复制报错,比如主键冲突、记录不存在(而 aaaa:101 这个之前复制报错的事务必定是修改表 t 的事务)
解决办法:启动复制时跳过 aaaa:101-10000 这些事务中修改表 t 的事务 。
正确的修复步骤:
1. 在主库上备份表 t (假设备份快照 GTID 为 aaaa:1-10000) , 恢复到从库;
2. 设置复制过滤 , 过滤表 t:
CHANGE REPLICATION FILTER REPLICATE_WILD_IGNORE_TABLE = ('db_name.t');
3. 启动复制,回放到 aaaa:10000 时停止复制(此时从库上所有表的数据都在同一状态,是一致的);
START SLAVE UNTIL SQL_AFTER_GTIDS = 'aaaa:10000';
4. 删除复制过滤,正常启动复制 。
【怎么把mysql的库复制 mysql数据库怎么复制】注意事项:这里要用 mysqldump --single-transaction --master-data=https://www.04ip.com/post/2,记录备份快照对应的 GTID
场景 2
如果复制报错后,使用跳过错误、复制过滤等办法修复了主从复制 。主、从库数据一直在更新 。
修复步骤:
在主库上备份表 t (假设备份快照 GTID为 aaaa:1-10000);
停止从库复制,GTID为 aaaa:1-20000;
恢复表 t 到从库;
启动复制 。
这里的问题是复制起始位点是 aaaa:20001,aaaa:10000-20000 这些事务将不会在从库上回放,如果这里面有修改表 t 数据的事务,从库上将丢失这部分数据 。
解决办法:从备份开始到启动复制,锁定表 t,保证 aaaa:10000-20000 中没有修改表 t 的事务 。
正确修复步骤:
对表 t 加读锁;
在主库上备份表 t;
停止从库复制,恢复表 t;
启动复制;
解锁表 t 。
如果是大表,这里可以用可传输表空间方式备份、恢复表,减少锁表时间 。
如何复制mysql数据库到另一台电脑上?这种架构一般用在以下三类场景
1. 备份多台 Server 的数据到一台如果按照数据切分方向来讲,那就是垂直切分 。比如图 2,业务 A、B、C、D 是之前拆分好的业务,现在需要把这些拆分好的业务汇总起来备份,那这种需求也很适用于多源复制架构 。实现方法我大概描述下:业务 A、B、C、D 分别位于 4 台 Server,每台 Server 分别有一个数据库来隔离前端的业务数据,那这样,在从库就能把四台业务的数据全部汇总起来,而不需要做额外的操作 。那没有多源复制之前,要实现这类需求,只能在汇总机器上搭建多个 MySQL 实例 , 那这样势必会涉及到跨库关联的问题,不但性能急剧下降,管理多个实例也没有单台来的容易 。
2. 用来聚合前端多个 Server 的分片数据 。
同样,按照数据切分方向来讲,属于水平切分 。比如图 3,按照年份拆分好的数据,要做一个汇总数据展现,那这种架构也非常合适 。实现方法稍微复杂些:比如所有 Server 共享同一数据库和表 , 一般为了开发极端透明,前端配置有分库分表的中间件,比如爱可生的 DBLE 。
推荐阅读
- 码云看到java代码,码云怎么fork
- 电视怎么查看使用多久时间,怎样查电视使用时间
- 实名农户电商如何,实名农户电商如何注册
- linux读文件命令 linux 文件读取命令
- ios10系统如何删除软件更新,ios怎么删除软件更新包
- win10系统如何装虚拟机,win10系统如何装虚拟机系统
- php查询数据如何显示 php查询数据表
- 鸿蒙升级太卡,升级鸿蒙 变慢
- linux判断上条命令,linux条件判断语句