scp是secure copy的簡寫,用于在Linux下進行遠端拷貝檔案的指令,和它類似的指令有cp,不過cp隻是在本機進行拷貝不能跨伺服器,而且scp傳輸是加密的。
指令格式
scp [參數] [源路徑] [目的路徑]
** 如果目的位址存在相同的檔案,将會被覆寫 **
指令功能
scp是 secure copy的縮寫, scp是linux系統下基于ssh登陸進行安全的遠端檔案拷貝指令。linux的scp指令可以在linux伺服器之間複制檔案和目錄。
指令參數
-1 強制scp指令使用協定ssh1
-2 強制scp指令使用協定ssh2
-4 強制scp指令隻使用IPv4尋址
-6 強制scp指令隻使用IPv6尋址
-B 使用批處理模式(傳輸過程中不詢問傳輸密碼或短語)
-C 允許壓縮。(将-C标志傳遞給ssh,進而打開壓縮功能)
-p 保留原檔案的修改時間,通路時間和通路權限。
-q 不顯示傳輸進度條。
-r 遞歸複制整個目錄。
-v 詳細方式顯示輸出。scp和ssh(1)會顯示出整個過程的調試資訊。這些資訊用于調試連接配接,驗證和配置問題。
-c cipher 以cipher将資料傳輸進行加密,這個選項将直接傳遞給ssh。
-F ssh_config 指定一個替代的ssh配置檔案,此參數直接傳遞給ssh。
-i identity_file 從指定檔案中讀取傳輸時使用的密鑰檔案,此參數直接傳遞給ssh。
-l limit 限定使用者所能使用的帶寬,以Kbit/s為機關。
-o ssh_option 如果習慣于使用ssh_config(5)中的參數傳遞方式,
-P port 注意是大寫的P, port是指定資料傳輸用到的端口号
-S program 指定加密傳輸時所使用的程式。此程式必須能夠了解ssh(1)的選項。
使用執行個體
從本地伺服器複制到遠端伺服器:
(1) 複制檔案:
指令格式:
scp local_file [email protected]_ip:remote_folder
注意,如果目的目錄裡存在相同的檔案,檔案會被覆寫掉,如果不想覆寫,需要指定目的檔案名
或者
scp local_file [email protected]_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 [email protected]_ip:remote_folder
或者
scp -r local_folder remote_ip:remote_folder
第1個指定了使用者名,指令執行後需要輸入使用者密碼;
第2個沒有指定使用者名,指令執行後需要輸入使用者名和密碼;
從遠端伺服器複制到本地伺服器:
從遠端複制到本地的scp指令與上面的指令雷同,隻要将從本地複制到遠端的指令後面2個參數互換順序就行了。
執行個體1:從遠處複制檔案到本地目錄
指令:
scp [email protected]:/opt/soft/nginx-0.5.38.tar.gz /opt/soft/