概念
scp是secure copy的簡寫, 是 linux 系統下基於 ssh 登陸進行安全的遠程文件拷貝命令。scp 是加密的,rcp 是不加密的,scp 是 rcp 的加強版。
因為scp傳輸是加密的,可能會稍微影響一下速度。另外,scp還非常不占資源,不會提高多少系統負荷,在這一點上,rsync就遠遠不及它了。雖然 rsync比scp會快一點,但當小文件眾多的情況下,rsync會導致硬盤I/O非常高,而scp基本不影響系統正常使用。
語法
scp [-1246BCpqrv] [-c cipher] [-F ssh_config] [-i identity_file]
[-l limit] [-o ssh_option] [-P port] [-S program]
[[user@]host1:]file1 [...] [[user@]host2:]file2
簡易寫法:
scp [可選參數] file_source file_target
參數說明:
-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)的選項。
命令實例
預置條件:
本例在vmware打開了兩個ubuntu。
ubuntu A 地址:192.168.6.186,並開啟了ssh服務器
ubuntu B 地址:192.168.6.111
安裝ssh命令如下:
apt-get install openssh-server
開啟ssh服務器指令【ubuntu A】:
/etc/init.d/ssh restart
執行結果如下:
例1 下載文件
把192.168.6.186服務器的t.log拷貝到當前服務器的當前目錄下;
scp -r root@192.168.6.186:/home/peng/test/t.log ./
執行結果如下:
例2 上傳文件
scp icons.png root@192.168.1.1:/root/下載 #本機文件,copy遠程服務器
執行結果:
例3 下載目錄
- 以root用戶登錄ubuntu A的ssh服務器,並將文件夾copy到本地
scp -r root@192.168.6.186:/home/peng/driver/list /home/peng/test
執行結果【ubuntu B】:
- 將本地文件copy到服務器,添填寫用戶,默認當前用戶
scp /home/peng/test/t.log 192.168.6.186:/home/peng/test
執行結果【ubuntu B】:
看到錯誤提示:Permission denied,這個錯誤是因為服務器A的文件夾/home/peng/test沒有修改權限。
進入ubuntu A
再次執行命令 【ubuntu B】:
【ubuntu A】
例4 指定端口
使用指定端口從本地拷到遠程服務器
scp -P 20022 -r /home/peng/test/list root@192.168.6.186:/home/peng/test
例5 使用證書
使用證書登錄,並遞歸的將遠程目錄下載到本地,同時指定了所需要的端口號。
scp -r -i /Users/test/wx_Document/private.crt -P 2323 root@10.135.178.6:/data/htdocs/www/logs /Users/local