scp是secure copy的簡寫,用於在 Linux 下進行遠程拷貝文件的命令,和它類似的命令有cp,不過cp只是在本機進行拷貝不能跨服務器。
scp傳輸是加密的,可能會稍微影響一下速度。當你服務器硬盤變為只讀 read only system時,用scp可以幫你把文件移出來。

另外,scp還非常不占資源,不會提高多少系統負荷,在這一點上,rsync就遠遠不及它了。雖然 rsync比scp會快一點,但當小文件眾多的情況下,rsync會導致硬盤I/O非常高,而scp基本不影響系統正常使用。
scp命令格式
#文件下載
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)的選項。
scp文件上傳下載示例
從服務器下載文件
scp username@servername:/path/filename /tmp/local_destination,例如:
scp codinglog@192.168.0.101:/home/kimi/test.txt /tmp/local_destination
把192.168.0.101上的/home/kimi/test.txt的文件下載到 /tmp/local_destination
從服務器下載整個目錄
scp -r username@servername:remote_dir/ /tmp/local_dir ,例如:
scp -r codinglog@192.168.0.101 /home/kimi/test /tmp/local_dir
把192.168.0.101上的/home/kimi/test目錄,下載到本地目錄
上傳本地文件到服務器
scp /path/local_filename username@servername:/path ,例如:
scp /var/www/test.php codinglog@192.168.0.101:/var/www/
把本機/var/www/目錄下的test.php文件上傳到192.168.0.101這台服務器上的/var/www/目錄中
上傳目錄到服務器
scp -r /tmp/local_dir username@servername:remote_dir,例如:
scp -P 22 -r test codinglog@192.168.0.101:/var/www/
把本地目錄下的test目錄上傳到服務器的/var/www/ 目錄
