您的位置:首页 > 数据库 > MySQL

MySQL如何跨机器迁移数据?

2018-02-04 20:22 399 查看
经常会遇到如此需求,需把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
中有数据库表
users
users
表中有一条记录。

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


注意:当迁移某个数据库时,需要提前在目标主机中创建好该数据库。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: