MySQL如何跨机器迁移数据?

经常会遇到如此需求,需把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

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

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将MySQL 5.1的数据迁移到新的数据库,您可以按照以下步骤进行操作: 1. 确保已经将MySQL数据库升级到5.6以上版本,因为Nacos只支持5.6以上的MySQL版本[1]。 2. 备份原始的MySQL 5.1数据库中的所有数据。 3. 创建一个新的MySQL 5.6或更高版本的数据库,并确保该数据库已正确安装和配置。 4. 将备份的数据导入到新的MySQL数据库中。 5. 针对Nacos的要求,在迁移数据之前,请确保将原MySQL安装目录下的data目录中的ibdata1文件覆盖到新的MySQL数据目录中。 6. 启动新的MySQL数据库,并验证数据是否成功导入。 7. 确保您的项目环境已经配置好了Python环境、node.js前端环境和MySQL数据库。 8. 运行您的项目,并确保它可以连接到新的MySQL数据库。 通过按照以上步骤进行操作,您应该能够成功迁移MySQL 5.1的数据至新的数据库。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Mysql5.5版本数据迁移至5.7版本](https://blog.csdn.net/weixin_57882850/article/details/123518127)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [基于Django+node.js+MySQL+杰卡德相似系数智能新闻推荐系统-机器学习算法应用(含Python源码)+数据集](https://download.csdn.net/download/qq_31136513/88285126)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值