【MySQL】利用mysqldump进行mysql数据库的数据备份/迁移

一、mysqldump备份常见用法

1、导出整个数据库(包括数据库中的数据)

mysqldump -u username -p password dbname > dbname.sql    

2、导出数据库结构(不含数据)

mysqldump -u username -p password   -d dbname > dbname.sql    

3、导出数据库中的某张数据表(包含数据)

mysqldump -u username -p password dbname tablename > tablename.sq

mysqldump -u username -p password -B dbname --table tablename > tablename.sql

4、导出数据库中的某张数据表的表结构(不含数据)

mysqldump -u username -p password -d dbname tablename > tablename.sql 

5、备份数据库时使用参数(--ignore-table)排除某个表或多个表

mysqldump -u username  -p password --ignore-table=dbname.table1 --ignore-table=dbname.table2 dbname > /opt/backup.sql

 

二、使用scp命令将sql脚本复制到其他服务器

 scp是secure copy的简写,用于在Linux下进行远程拷贝文件的命令, scp传输是加密的,可能会稍微影响一下速度。另外,scp还非常不占资源,不会提高多少系统负荷,在这一点上,rsync就远远不及它了。虽然 rsync比scp会快一点,但当小文件众多的情况下,rsync会导致硬盘I/O非常高,而scp基本不影响系统正常使用

scp命令的实际应用概述: 

从本地服务器复制到远程服务器:

(1) 复制文件: 

命令格式:

scp local_file remote_username@remote_ip:remote_folder  

或者

scp local_file remote_username@remote_ip:remote_file  

或者

scp local_file remote_ip:remote_folder  

或者

scp local_file remote_ip:remote_file  

第1,2个指定了用户名,命令执行后需要输入用户密码,第1个仅指定了远程的目录,文件名字不变,第2个指定了文件名  

第3,4个没有指定用户名,命令执行后需要输入用户名和密码,第3个仅指定了远程的目录,文件名字不变,第4个指定了文件名  

(2) 复制目录: 

命令格式:

scp -r local_folder remote_username@remote_ip:remote_folder  

或者

scp -r local_folder remote_ip:remote_folder  

第1个指定了用户名,命令执行后需要输入用户密码;  

第2个没有指定用户名,命令执行后需要输入用户名和密码

如:scp dbname.sql [email protected]:/home/

注意与ssh命令的差别:username:[email protected]  或 ssh [email protected]

三、导入数据库

将数据重新读入mysql数据中,将sql文件读取进mysql数据库中有两种方法。

利用mysql命令将备份数据读取至数据库中

mysql -u username -p password < dbname.sql

nohup mysql -u username -p password -f dbname < dbname.sql > /dev/null 2>&1 & (在导入较大的sql文件时可以放到后台执行)-f强制导入,忽略错误信息

利用source命令将备份数据读取至数据库中

如果我们想要读取的数据库尚不存在,则首先创建一个相应的数据库

$ mysql -u root -p
MySQL > set names utf8;
mysql > create database dbname;

然后执行如下mysql命令(需要首先确认dbname.sql文件存在于当前路径下或者指定绝对路径):

mysql > use dbname;
mysql > source dbname.sql;

其他扩展阅读,可以使用阿里云提供的DTD工具迁移

猜你喜欢

转载自blog.csdn.net/xia296/article/details/90370591