Linux 使用scp命令定時將文件備份到另一台服務器
scp是secure copy的簡寫,用於在Linux下進行遠程拷貝文件的命令,和它類似的命令有cp,不過cp只是在本機進行拷貝不能跨服務器,而且scp傳輸是加密的。可能會稍微影響一下速度。當你服務器硬盤變為只讀 read only system時,用scp可以幫你把文件移出來。另外,scp還非常不占資源,不會提高多少系統負荷,在這一點上,rsync就遠遠不及它了。雖然 rsync比scp會快一點,但當小文件眾多的情況下,rsync會導致硬盤I/O非常高,而scp基本不影響系統正常使用。
舉例:
拷貝本機的一個文件到另一台Linux計算機
scp /home/tmp.text root@192.168.1.88:/home/data
說明:上述命令是拷貝本地home文件夾下面的一個tmp.text文件到一台ip地址為192.168.1.88的計算機中,拷貝的路徑為該計算機root用戶下的/home/data文件夾下面
語法介紹
scp [參數] [Source_File] [Dest_File]
參數介紹
-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)的選項。
使用示例
1、從本機拷貝一個文件夾及其下面的文件到另一台IP為192.168.1.88的計算機中
scp -r /home/data_source root@192.168.1.88:/home/data_Dest
# 注:-r 遞歸拷貝 本地文件夾為/home/data_source,把這些拷貝到目標機器的data_Dest文件夾下面。
2、從目標機拷貝到本機
scp root@192.168.1.88:/home/data/tets1.text /home/data
# 從遠程主機上拷貝一個文件到本地文件/home/data下面
scp -r root@192.168.1.88:/home/data /home/destfile
# 從遠程主機上拷貝一個文件夾及其下面的文件到本地/home/destfile文件夾下面