scp 跨機遠程拷貝

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

註解

類似的工具有rsync;scp消耗資源少,不會提高多少系統負荷,在這一點上,rsync就遠遠不及它了。rsync比scp會快一點,但當小文件多的情況下,rsync會導致硬盤I/O非常高,而scp基本不影響系統正常使用。

18.1. 命令格式:

scp [參數] [原路徑] [目標路徑]

18.2. 命令參數:

  • -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)的選項。

18.3. 使用說明

從本地服務器複製到遠程服務器

複製文件:

$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

指定了用戶名,命令執行後需要輸入用戶密碼;如果不指定用戶名,命令執行後需要輸入用戶名和密碼;

複製目錄:

$scp -r local_folder remote_username@remote_ip:remote_folder
$scp -r local_folder remote_ip:remote_folder

第1個指定了用戶名,命令執行後需要輸入用戶密碼; 第2個沒有指定用戶名,命令執行後需要輸入用戶名和密碼;

註解

從遠程複製到本地的scp命令與上面的命令一樣,只要將從本地複製到遠程的命令後面2個參數互換順序就行了。

18.4. 使用示例

實例1:從遠處複製文件到本地目錄

$scp root@10.6.159.147:/opt/soft/demo.tar /opt/soft/

說明: 從10.6.159.147機器上的/opt/soft/的目錄中下載demo.tar 文件到本地/opt/soft/目錄中

實例2:從遠處複製到本地

$scp -r root@10.6.159.147:/opt/soft/test /opt/soft/

說明: 從10.6.159.147機器上的/opt/soft/中下載test目錄到本地的/opt/soft/目錄來。

實例3:上傳本地文件到遠程機器指定目錄

$scp /opt/soft/demo.tar root@10.6.159.147:/opt/soft/scptest

說明: 複製本地opt/soft/目錄下的文件demo.tar 到遠程機器10.6.159.147的opt/soft/scptest目錄

實例4:上傳本地目錄到遠程機器指定目錄

$scp -r /opt/soft/test root@10.6.159.147:/opt/soft/scptest

說明: 上傳本地目錄 /opt/soft/test到遠程機器10.6.159.147上/opt/soft/scptest的目錄中


书籍推荐