怎么把mysql的库复制 mysql怎么复制数据库数据

如何复制mysql数据库到另一台电脑上?这种架构一般用在以下三类场景
1. 备份多台 Server 的数据到一台如果按照数据切分方向来讲 , 那就是垂直切分 。比如图 2,业务 A、B、C、D 是之前拆分好的业务,现在需要把这些拆分好的业务汇总起来备份,那这种需求也很适用于多源复制架构 。实现方法我大概描述下:业务 A、B、C、D 分别位于 4 台 Server,每台 Server 分别有一个数据库来隔离前端的业务数据,那这样,在从库就能把四台业务的数据全部汇总起来,而不需要做额外的操作 。那没有多源复制之前,要实现这类需求,只能在汇总机器上搭建多个 MySQL 实例,那这样势必会涉及到跨库关联的问题 , 不但性能急剧下降,管理多个实例也没有单台来的容易 。
2. 用来聚合前端多个 Server 的分片数据 。
同样 , 按照数据切分方向来讲 , 属于水平切分 。比如图 3,按照年份拆分好的数据,要做一个汇总数据展现 , 那这种架构也非常合适 。实现方法稍微复杂些:比如所有 Server 共享同一数据库和表,一般为了开发极端透明,前端配置有分库分表的中间件,比如爱可生的 DBLE 。
3. 汇总并合并多个 Server 的数据
第三类和第一种场景类似 。不一样的是不仅仅是数据需要汇总到目标端,还得合并这些数据,这就比第一种来的相对复杂些 。比如图 4,那这样的需求,是不是也适合多源复制呢?答案是 YES 。那具体怎么做呢?
如何复制MySQL数据库或表到另外一台服务器?使用这种方法前怎么把mysql的库复制,我们需要先下载一个MySQL客户端工具SqlYog 。点击这里下载并安装\x0d\x0a\x0d\x0a下面我们开始复制数据库怎么把mysql的库复制:\x0d\x0a1、打开SqlYog community Edition,分别在不同怎么把mysql的库复制的选项卡中打开源数据库服务器与目标数据库服务器,这一点很重 。\x0d\x0a\x0d\x0a在源数据库服务器选项卡中你将看到所有数据库列表 。\x0d\x0a2、在需要复制迁移怎么把mysql的库复制的数据库上右击,在弹出菜单中选择“Copy Database to Different Host/Database”\x0d\x0a3、在弹出对话框中,我们能看到源数据库服务器及目标服务器,在左边,通过勾选复选框来选择需要复制迁移的对象,如表、函数、触发器等,也可以选择所有对象 。\x0d\x0a4、在右边选择需要迁移的目标服务器或数据库\x0d\x0a5、根据你的需要选择复制类型怎么把mysql的库复制:“Structure and Data”或“Structure only”,即“结构和数据”或“仅结构” 。\x0d\x0a6、选择结束后点击“Copy”按钮开始复制,知道数据迁移结束 。
如何将mysql的一个完整数据库全部复制到另外一个数据库?如果从库上表 t 数据与主库不一致,导致复制错误 , 整个库的数据量很大,重做从库很慢 , 如何单独恢复这张表的数据?通常认为是不能修复单表数据的 , 因为涉及到各表状态不一致的问题 。下面就列举备份单表恢复到从库会面临的问题以及解决办法:
场景 1
如果复制报错后,没有使用跳过错误、复制过滤等方法修复主从复制 。主库数据一直在更新,从库数据停滞在报错状态(假设 GTID 为 aaaa:1-100) 。
修复步骤:
在主库上备份表 t (假设备份快照 GTID 为 aaaa:1-10000);
恢复到从库;
启动复制 。
这里的问题是复制起始位点是 aaaa:101,从库上表 t 的数据状态是领先其他表的 。aaaa:101-10000 这些事务中只要有修改表 t 数据的事务,就会导致复制报错 ,比如主键冲突、记录不存在(而 aaaa:101 这个之前复制报错的事务必定是修改表 t 的事务)

推荐阅读