MySQL如何跨机器迁移数据?
2018-02-04 20:22
399 查看
经常会遇到如此需求,需把A主机上的MySQL数据库所有迁移到B主机上,或者部分数据库,所以接下来将介绍迁移所有数据库和迁移单个数据库时的数据迁移步骤。
系统版本:CentOS 6.8
MySQL版本:5.5
源主机有以下数据库
查看数据库
其中,数据库
系统版本:CentOS 6.8
MySQL版本:5.5
目标主机有以下数据库:
源主机比目标主机多一个名为
OK,开始环境介绍完后,先介绍迁移所有数据。
在源主机备份所有数据库:
提示输入
拷贝备份文件
在目标主机还原所有数据库:
提示输入
验证是否成功:
由此可见,目标主机上已经备份成功了源主机中所有数据库。
注意:当迁移所有数据库时,不用提前在目标主机创建好所有数据库。
在源主机备份数据库
提示输入
拷贝备份文件
在目标主机中创建好数据库
在目标主机还原数据库
提示输入
验证是否成功:
由此可见,目标主机上已经备份成功了源主机中数据库
注意:当迁移某个数据库时,需要提前在目标主机中创建好该数据库。
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。
注意:当迁移某个数据库时,需要提前在目标主机中创建好该数据库。
相关文章推荐
- MySQL------如何将SQLServer文件数据迁移到MySQL
- [MySQL FAQ]系列 -- 如何跨时区迁移数据
- mysql数据迁移到mongoDB中,如何操作?
- MySQL如何跨时区迁移数据
- [MySQL FAQ]系列 -- 如何跨时区迁移数据
- 如何优雅的将数据从sqlite3迁移到mysql
- 如何从把mysql的数据迁移到oracle上来---------Oracle SQL Developer技术
- 如何把sqlserver数据迁移到mysql数据库及需要注意事项
- 经纬度如何在mysql 数据库中定义数据类型.
- 如何在MyEclipse中使用MyBatis将MySQL数据表生成相应的实体类和映射文件
- 使用perl实现拆分数据表(mysql)并迁移数据实例
- MySQL如何导入csv格式数据文件解决方案
- Linux Centos 迁移Mysql 数据位置
- MySQL如何从表中取出随机数据
- Mysql如何指定新插入的数据的起始自增主键id
- mysql 备份数据迁移,出错的处理
- MySQL中, 如何查询某一天, 某一月, 某一年的数据.
- 从百万级别数据的分析角度,Mysql,Mongodb,Hbase如何选择?
- mysql 在删除数据出现Cannot delete or update a parent row: a foreign key constraint fails 这个该如何解决
- 编码素养问题收集4:MySQL数据导入导出如何证明结果是正确的?