使用scp命令在多個Linux系統間進行文件復制


一,什么是scp

scp是linux系統下基於ssh登陸進行安全的遠程文件拷貝命令。scp命令可以在linux服務器之間復制文件和目錄.scp使用ssh安全協議傳輸數據,具有和ssh一樣的驗證機制,從而安全的遠程拷貝文件。

從一個linux系統中上傳,下載文件或目錄時,用的最多的是ftp,用ftp的話,要登錄,登錄后要進行目錄的切換,在get和put,感覺挺麻煩的,並且用ftp比較慢的,特別是有圖形界面的ftp(例如:gftp)。當然我們可以用rsync,用它呢,就必須保持二個服務器間的目錄啊,文件要一樣,適用范圍就受到限制了,方法有很多。scp還是比較方便和快速的。

 

二,scp參數及說明
[root@tank test]# scp --help
usage: 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

-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實例
1,下載目錄
[root@test test]# scp -r root@172.30.4.42:/tmp/test2 ./

將172.30.4.42linux系統中/tmp/test2目錄copy到當前目錄下面,在這172.30.4.42前面加了root@,提示輸入密碼,如果不加呢,會提示你輸入用戶名和密碼

2,下載文件
[root@test test]# scp 172.30.4.42:/tmp/test2/aaa.php ./

將172.30.4.42linux系統中/tmp/test2/aaa.php文件copy到當前目錄下面

3,上傳目錄
[root@test test]# scp -r ./mytest 172.30.4.42:/tmp/test2

將當前目錄中的mytest目錄上傳到172.30.4.42服務器/tmp/test2目錄下面。

4,上傳文件
[root@test test]# scp ./mytest/password.php 172.30.4.42:/tmp/test2

將當前目錄中的mytest目錄下的password.php上傳到172.30.4.42服務器/tmp/test2目錄下面。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM