一、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;