MySQL如何跨机器迁移数据?

by LauCyun Dec 12,2016 10:07:01 6,373 views

经常会遇到如此需求,需把A主机上的MySQL数据库所有迁移到B主机上,或者部分数据库,所以接下来将介绍迁移所有数据库和迁移单个数据库时的数据迁移步骤。

1 实验环境

A主机(源主机):

  • IP地址:192.168.0.191
  • 系统版本:CentOS 6.8
  • MySQL版本:5.5
  • 源主机有以下数据库
    mysql> show databases;
    +--------------------+
    | Database           |
    +--------------------+
    | information_schema |
    | laucyun            |
    | mysql              |
    | performance_schema |
    +--------------------+
    4 rows in set (0.00 sec)
    查看数据库laucyun内容:
    mysql> show tables;
    +-------------------+
    | Tables_in_laucyun |
    +-------------------+
    | users             |
    +-------------------+
    1 row in set (0.00 sec)
    
    mysql> select * from users;
    +----+----------+----------+----------------+
    | id | username | password | email          |
    +----+----------+----------+----------------+
    |  1 | laucyun  | 123456   | liu@liuker.xyz |
    +----+----------+----------+----------------+
    1 row in set (0.00 sec)
    
    其中,数据库laucyun中有数据库表usersusers表中有一条记录。

B主机(目标主机):

  • IP地址:192.168.0.192
  • 系统版本:CentOS 6.8
  • MySQL版本:5.5
  • 目标主机有以下数据库:
    mysql> show databases;
    +--------------------+
    | Database           |
    +--------------------+
    | information_schema |
    | mysql              |
    | performance_schema |
    +--------------------+
    3 rows in set (0.00 sec)

源主机比目标主机多一个名为laucyun的数据库。

OK,开始环境介绍完后,先介绍迁移所有数据。

2 迁移所有数据库

目前实验环境中,源主机比目标主机多一个名为laucyun的数据库。

在源主机备份所有数据库:

$ mysqldump -uroot -p --all-databases > /home/all_databases.bak

提示输入root用户的密码,备份文件信息如下:

$ ll
total 552
-rw-r--r-- 1 root root 561449 Dec 31 13:02 all_databases.bak

拷贝备份文件all_databases.bak到目标主机:

$ scp all_databases.bak root@192.168.0.192:/home/

在目标主机还原所有数据库:

$ mysql -uroot -p < /home/all_databases.bak

提示输入root用户的密码。

验证是否成功:

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| laucyun            |
| mysql              |
| performance_schema |
+--------------------+
4 rows in set (0.00 sec)

mysql> use laucyun;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> show tables;
+-------------------+
| Tables_in_laucyun |
+-------------------+
| users             |
+-------------------+
1 row in set (0.00 sec)

mysql> select * from users;
+----+----------+----------+----------------+
| id | username | password | email          |
+----+----------+----------+----------------+
|  1 | laucyun  | 123456   | liu@liuker.xyz |
+----+----------+----------+----------------+
1 row in set (0.00 sec)

由此可见,目标主机上已经备份成功了源主机中所有数据库。

注意:当迁移所有数据库时,不用提前在目标主机创建好所有数据库。

3 迁移某个数据库

目前实验环境中,源主机比目标主机多一个名为laucyun的数据库。

在源主机备份数据库laucyun

$ mysqldump -uroot -p laucyun > /home/laucyun.bak

提示输入root用户的密码,备份文件信息如下:

$ ll
total 4
-rw-r--r-- 1 root root 1982 Dec 31 13:52 laucyun.bak

拷贝备份文件laucyun.bak到目标主机:

$ scp laucyun.bak root@192.168.0.192:/home/

在目标主机中创建好数据库laucyun

mysql> CREATE DATABASE `laucyun` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
Query OK, 1 row affected (0.00 sec)

在目标主机还原数据库laucyun

$ mysql -uroot -p laucyun < /home/laucyun.bak

提示输入root用户的密码。

验证是否成功:

mysql> show tables;
+-------------------+
| Tables_in_laucyun |
+-------------------+
| users             |
+-------------------+
1 row in set (0.00 sec)

mysql> select * from users;
+----+----------+----------+----------------+
| id | username | password | email          |
+----+----------+----------+----------------+
|  1 | laucyun  | 123456   | liu@liuker.xyz |
+----+----------+----------+----------------+
1 row in set (0.00 sec)

由此可见,目标主机上已经备份成功了源主机中数据库laucyun

注意:当迁移某个数据库时,需要提前在目标主机中创建好该数据库。

Tags