如何复制mysql数据库到另一台电脑上?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何复制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。那具体怎么做呢?

参考技术A 有两种办法。
1、在B机器上装mysql。
将A机器上的mysql/data下的你的数据库目录整个拷贝下来。
将B机器上的mysql服务停止。
找到B机器上的mysql/data目录,将你拷贝的目录粘贴进去,然后启动mysql服务就可以了。
2、使用SQL语句备份和恢复
你可以使用SELECT
INTO
OUTFILE语句备份数据,并用LOAD
DATA
INFILE语句恢复数据。这种方法只能导出数据的内容,不包括表的结构,如果表的结构文件损坏,你必须要先恢复原来的表的结构。
语法:
SELECT
*
INTO
OUTFILE
¦
DUMPFILE
’file_name’
FROM
tbl_name
LOAD
DATA
[LOW_PRIORITY]
[LOCAL]
INFILE
’file_name.txt’
[REPLACE
¦
IGNORE]
INTO
TABLE
tbl_name
SELECT
...
INTO
OUTFILE
’file_name’
在dos命令提示符下使用mysqldump命令进行备份.
如下:
C:\Documents
and
Settings\Administrator>mysqldump
yinshi
>c:\\backup.txt
-uroot
-p12142022本回答被提问者采纳

如何复制MySQL数据库或表到另外一台服务器

两种方法:

    使用sqlyog等数据库工具的数据同步功能,可以将数据库复制到别的服务器

    将源数据导出为sql文件,然后在新服务器导入

参考技术A

Asynchronous Replication Automatic failover

其原理是在一条异步复制通道上配置多个可用复制源,当某个复制源不可用时(宕机、复制链路中断),且 slave 的 IO 线程尝试重连无效,自动根据权重选择新的源继续同步。

    准备一个 MGR 集群和单实例,模拟复制链路切换,当 primary 故障,slave 自动切换到其他节点。dbdeployer deploy replication --topology=group 8.0.22 --single-primarydbdeployer deploy single 8.0.22

    2. 在从机上建立指向 MGR 主节点的复制通道,

    change master to master_user='msandbox',master_password='msandbox', master_host='127.0.0.1',master_auto_position=1,source_connection_auto_failover=1,master_port=23223,master_retry_count=6,master_connect_retry=10 for channel 'mgr-single';

    在 master_retry_count 和 master_connect_retry 的设置上要考虑尝试重连多久才切换复制源。

    3. 在从机上配置 asynchronous connection auto failover

    配置 asynchronous connection auto failover 的两个函数:

    asynchronous_connection_failover_add_source(channel-name,host,port,network-namespace,weight)

    asynchronous_connection_failover_delete_source(channel-name,host,port,network-namespace)

    权重值大的被优先级选择,可以配合MGR的选举权重配置 asynchronous_connection_failover 的权重。当 MGR 节点切换,异步复制也能切换到新的主节点。

    SELECT asynchronous_connection_failover_add_source('mgr-single','127.0.0.1',23223,null,100); SELECT asynchronous_connection_failover_add_source('mgr-single','127.0.0.1',23224,null,80); SELECT asynchronous_connection_failover_add_source('mgr-single','127.0.0.1',23225,null,50);start slave for channel 'mgr-single';


    4. 检查异步复制通道是否启用 failover。

    mysql> SELECT CHANNEL_NAME, SOURCE_CONNECTION_AUTO_FAILOVER FROM performance_schema.replication_connection_configuration; +--------------+---------------------------------+| CHANNEL_NAME | SOURCE_CONNECTION_AUTO_FAILOVER |+--------------+---------------------------------+| mgr-single   |  1                              |+--------------+---------------------------------+1 row in set (0.01 sec


    5. 把 MGR 的 primary 节点 kill 掉,这个从节点会在尝试几轮重连失败后自动切换到次权重的复制源,其日志中会输出切换信息。

    注意:当主节点故障,一旦复制链路成功 failover 后,在新的复制链路没有故障时,如果原主节点恢复,是不会回切的。如果当前复制链路发生故障,会再次选择权重高的进行切换

以上是关于如何复制mysql数据库到另一台电脑上?的主要内容,如果未能解决你的问题,请参考以下文章

如何复制MySQL数据库或表到另外一台服务器

如何复制MySQL数据库或表到另外一台服务器

如何复制MySQL数据库或表到另外一台服务器?

如何将我的 MySQL 数据库转移到另一台计算机?

如何将sql数据库自动定时的备份或更新到另一台电脑

MYSQL文件复制及备份