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