【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工具遷移

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章