scp命令的用處:
scp在網(wǎng)絡(luò)上不同的主機(jī)之間復(fù)制文件,它使用ssh安全協(xié)議傳輸數(shù)據(jù),具有和ssh一樣的驗(yàn)證機(jī)制,從而安全的遠(yuǎn)程拷貝文件。
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命令的參數(shù)說(shuō)明:
-1
強(qiáng)制scp命令使用協(xié)議ssh1
-2
強(qiáng)制scp命令使用協(xié)議ssh2
-4
強(qiáng)制scp命令只使用IPv4尋址
-6
強(qiáng)制scp命令只使用IPv6尋址
-B
使用批處理模式(傳輸過(guò)程中不詢問(wèn)傳輸口令或短語(yǔ))
-C
允許壓縮。(將-C標(biāo)志傳遞給ssh,從而打開(kāi)壓縮功能)
-p 保留原文件的修改時(shí)間,訪問(wèn)時(shí)間和訪問(wèn)權(quán)限。
-q
不顯示傳輸進(jìn)度條。
-r
遞歸復(fù)制整個(gè)目錄。
-v 詳細(xì)方式顯示輸出。scp和ssh(1)會(huì)顯示出整個(gè)過(guò)程的調(diào)試信息。這些信息用于調(diào)試連接,驗(yàn)證和配置問(wèn)題。
-c cipher
以cipher將數(shù)據(jù)傳輸進(jìn)行加密,這個(gè)選項(xiàng)將直接傳遞給ssh。
-F ssh_config
指定一個(gè)替代的ssh配置文件,此參數(shù)直接傳遞給ssh。
-i identity_file
從指定文件中讀取傳輸時(shí)使用的密鑰文件,此參數(shù)直接傳遞給ssh。
-l limit
限定用戶所能使用的帶寬,以Kbit/s為單位。
-o ssh_option
如果習(xí)慣于使用ssh_config(5)中的參數(shù)傳遞方式,
-P port 注意是大寫(xiě)的P, port是指定數(shù)據(jù)傳輸用到的端口號(hào)
-S program
指定加密傳輸時(shí)所使用的程序。此程序必須能夠理解ssh(1)的選項(xiàng)。
scp命令的實(shí)際應(yīng)用
1>從本地服務(wù)器復(fù)制到遠(yuǎn)程服務(wù)器
(1) 復(fù)制文件:
命令格式:
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
第1,2個(gè)指定了用戶名,命令執(zhí)行后需要輸入用戶密碼,第1個(gè)僅指定了遠(yuǎn)程的目錄,文件名字不變,第2個(gè)指定了文件名
第3,4個(gè)沒(méi)有指定用戶名,命令執(zhí)行后需要輸入用戶名和密碼,第3個(gè)僅指定了遠(yuǎn)程的目錄,文件名字不變,第4個(gè)指定了文件名
實(shí)例:
scp /home/linux/soft/scp.zip root@www.mydomain.com:/home/linux/others/soft
scp /home/linux/soft/scp.zip root@www.mydomain.com:/home/linux/others/soft/scp2.zip
scp /home/linux/soft/scp.zip www.mydomain.com:/home/linux/others/soft
scp /home/linux/soft/scp.zip www.mydomain.com:/home/linux/others/soft/scp2.zip
(2) 復(fù)制目錄:
命令格式:
scp -r local_folder remote_username@remote_ip:remote_folder
或者
scp -r local_folder remote_ip:remote_folder
第1個(gè)指定了用戶名,命令執(zhí)行后需要輸入用戶密碼;
第2個(gè)沒(méi)有指定用戶名,命令執(zhí)行后需要輸入用戶名和密碼;
例子:
scp -r /home/linux/soft/ root@www.mydomain.com:/home/linux/others/
scp -r /home/linux/soft/ www.mydomain.com:/home/linux/others/
上面 命令 將 本地 soft 目錄 復(fù)制 到 遠(yuǎn)程 others 目錄下,即復(fù)制后遠(yuǎn)程服務(wù)器上會(huì)有/home/linux/others/soft/ 目錄
2>從遠(yuǎn)程服務(wù)器復(fù)制到本地服務(wù)器
從遠(yuǎn)程復(fù)制到本地的scp命令與上面的命令雷同,只要將從本地復(fù)制到遠(yuǎn)程的命令后面2個(gè)參數(shù)互換順序就行了。
例如:
scp root@www.mydomain.com:/home/linux/soft/scp.zip /home/linux/others/scp.zip
scp www.mydomain.com:/home/linux/soft/ -r /home/linux/others/
linux系統(tǒng)下scp命令中很多參數(shù)都和 ssh1 有關(guān) , 還需要看到更原汁原味的參數(shù)信息,可以運(yùn)行man scp 看到更細(xì)致的英文說(shuō)明.
scp命令在兩臺(tái)服務(wù)器直接進(jìn)行文件傳輸?shù)姆椒?/strong>
假設(shè)有兩臺(tái)機(jī)器,均為局域網(wǎng),兩機(jī)可相互通信無(wú)問(wèn)題,中間無(wú)防火墻。
兩機(jī)IP分別為:A:192.168.8.232 B:192.168.8.232
假設(shè)A,B機(jī)的SSH都允許root登錄
設(shè)要把 A上的 /root/abc.zip 傳到 B機(jī)并放到/abc目錄,可以在A機(jī)上用命令:
scp /root/abc.zip root@192.168.8.232:/abc/
若 SSH端口不是默認(rèn)的22,比如,是端口1234 則加-P參數(shù):
scp -P 1234 /root/abc.zip root@192.168.8.232:/abc/
也可以在B機(jī)上用命令:
scp root@192.168.8.232:/root/abc.zip /abc/
若 獲取服務(wù)器SSH端口不是默認(rèn)的22,比如,是端口 1234 則加-P參數(shù):
scp -P 1234 root@192.168.8.232:/root/abc.zip