scp是secure copy 的簡寫,用于在Linux 下進行遠端拷貝檔案的指令,和它類似的指令有cp,不過cp隻是在本機進行拷貝而不能跨伺服器,而且scp傳輸是加密的。可能會稍微影響一下速度。當你伺服器硬碟變為隻讀 read only system時,用scp 可以幫你把檔案移出來。另外,scp還非常不占資源,不會提高多少系統負荷,在這一點上, rsync就遠遠不及它了。雖然 rsync 比scp 會快一點,但當小檔案衆多的情況下,rsync會導緻硬碟 I/O 非常高,而 scp 基本不影響系統正常使用。
1.指令格式:
scp [參數] [原路徑] [目标路徑]
2.指令功能:
scp 是 secure copy 的縮寫,scp 是 Linux 系統下基于 ssh 登入進行安全的遠端檔案拷貝指令。Linux 的scp 指令可以在Linux 伺服器之間複制檔案和目錄。
3.指令參數:
-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)的選項
4.使用執行個體:
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 指令與上面的指令雷同,隻要将從本地複制到遠端的指令後面2個參數互換順序就行了。
執行個體1:從遠處複制檔案到本地目錄
指令:
scp [email protected]:/opt/soft/nginx-0.5.38.tar.gz /opt/soft/
執行個體2:從遠處複制到本地
scp -r [email protected]:/opt/soft/mongodb /opt/soft/
說明:從 192.168.1.1 機器上的 /opt/soft/中下載下傳 mongodb 目錄到本地的 /opt/soft/目錄來。
執行個體3:上傳本地檔案到遠端機器指定目錄
scp /opt/soft/aaa [email protected]:/opt/soft/aaa
說明:複制本地 opt/soft/目錄下的檔案 aaa 到遠端機器192.168.1.1的 opt/soft/aaa目錄
執行個體4:上傳本地目錄到遠端機器指定目錄
指令:scp -r /opt/soft/aaa [email protected]:/opt/soft/aaa
上傳本地目錄, /opt/soft/aaa到遠端機器 192.168.1.1的/opt/soft/aaa