Linux使用scp命令進行文件遠程拷貝詳解

前言

scp是 secure copy的縮寫, scp是Linux系統下基於ssh登陸進行安全的遠程文件拷貝命令。Linux的scp命令可以在Linux服務器之間複製文件和目錄。

使用語法:

scp  [參數] [源路徑] @IP:/目標路徑

scp 參數如下:

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

測試:server服務器ip192.168.43.117  backup服務器ip 192.168.43.200

從本地向遠端拷貝數據:

將server服務器/tmp/目錄拷貝到遠端backup服務器/text目錄下:

scp -r /tmp/ [email protected]: /text

在backup服務器上查看拷貝過來的數據:

從遠端向本地拷貝數據:

將backup服務器/text目錄下123.log文件拷貝到本地server服務器/tmp/目錄下:

scp [email protected]:/text/123.log /tmp/

scp是在Linux下進行遠程拷貝文件的命令,和它類似的命令有cp,不過cp只是在本機進行拷貝不能跨服務器,而且scp傳輸是加密的。可能會稍微影響一下速度。當你服務器硬盤變爲只讀 read only system時,用scp可以幫你把文件移出來。另外,scp還非常不佔資源,不會提高多少系統負荷,在這一點上,rsync就遠遠不及它了。雖然 rsync比scp會快一點,但當小文件衆多的情況下,rsync會導致硬盤I/O非常高,而scp基本不影響系統正常使用。scp在誇機器複製的時候爲了提高數據的安全性,使用了ssh連接和加密方式,如果機器之間配置了ssh免密碼登錄,那在使用scp的時候密碼都不用輸入。

 

您可能感興趣的文章:

文章同步發佈: https://www.geek-share.com/detail/2755486601.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章