每天學(xué)習(xí)一個(gè) Linux 指令 1 : scp
說明
scp是secure copy的簡(jiǎn)寫,用于在Linux下進(jìn)行遠(yuǎn)程拷貝文件的命令,和它類似的命令有cp,
不過cp只是在本機(jī)進(jìn)行拷貝不能跨服務(wù)器,而且scp傳輸是加密的。可能會(huì)稍微影響一下速度。當(dāng)你服務(wù)器硬盤變
為只讀 read only system時(shí),用scp可以幫你把文件移出來。另外,scp還非常不占資源,不會(huì)提高多少系統(tǒng)
負(fù)荷,在這一點(diǎn)上,rsync就遠(yuǎn)遠(yuǎn)不及它了。雖然 rsync比scp會(huì)快一點(diǎn),但當(dāng)小文件眾多的情況下,rsync會(huì)
導(dǎo)致硬盤I/O非常高,而scp基本不影響系統(tǒng)正常使用。
scp是linux系統(tǒng)下基于ssh登陸進(jìn)行安全的遠(yuǎn)程文件拷貝命令。linux的scp命令可以在linux服務(wù)器之間復(fù)制文件和目錄。
命令格式
scp [參數(shù)] [源路徑] [目標(biāo)路徑]
命令參數(shù)
scp [參數(shù)] [源路徑] [目標(biāo)路徑]
這里的參數(shù):
-1 強(qiáng)制scp命令使用協(xié)議ssh1
-2 強(qiáng)制scp命令使用協(xié)議ssh2
-4 強(qiáng)制scp命令只使用IPv4尋址
-6 強(qiáng)制scp命令只使用IPv6尋址
-B 使用批處理模式(傳輸過程中不詢問傳輸口令或短語)
-C 允許壓縮。(將-C標(biāo)志傳遞給ssh,從而打開壓縮功能)
-p 保留原文件的修改時(shí)間,訪問時(shí)間和訪問權(quán)限。
-q 不顯示傳輸進(jìn)度條。
-r 遞歸復(fù)制整個(gè)目錄。
-v 詳細(xì)方式顯示輸出。scp和ssh(1)會(huì)顯示出整個(gè)過程的調(diào)試信息。這些信息用于調(diào)試連接,驗(yà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 注意是大寫的P, port是指定數(shù)據(jù)傳輸用到的端口號(hào)
-S program 指定加密傳輸時(shí)所使用的程序。此程序必須能夠理解ssh(1)的選項(xiàng)。
實(shí)例
復(fù)制文件
命令執(zhí)行后需要輸入用戶密碼,第1個(gè)僅指定了遠(yuǎn)程的目錄,文件名字不變,第2個(gè)指定了文件名:
1. scp local_file remote_username@remote_ip:remote_folder
2. scp local_file remote_username@remote_ip:remote_file
第3,4個(gè)沒有指定用戶名,命令執(zhí)行后需要輸入用戶名和密碼,第3個(gè)僅指定了遠(yuǎn)程的目錄,文件名字不變,第4個(gè)指定了文件名
3. scp local_file remote_ip:remote_folder
4. scp local_file remote_ip:remote_file
復(fù)制目錄
scp -r local_folder remote_username@remote_ip:remote_folder : 指定了用戶名,命令執(zhí)行后需要輸入用戶密碼
scp -r local_folder remote_ip:remote_folder : 沒有指定用戶名,命令執(zhí)行后需要輸入用戶名和密碼
從遠(yuǎn)程服務(wù)器復(fù)制到本地服務(wù)器
從遠(yuǎn)程復(fù)制到本地的scp命令與上面的命令雷同,只要將從本地復(fù)制到遠(yuǎn)程的命令后面2個(gè)參數(shù)互換順序就行了。
例子 1 : 從遠(yuǎn)處復(fù)制文件到本地目錄
scp root@192.168.120.204:/opt/soft/nginx-0.5.38.tar.gz /opt/soft/
從192.168.120.204機(jī)器上的/opt/soft/的目錄中下載nginx-0.5.38.tar.gz 文件到本地/opt/soft/目錄中
例子 2 : 從遠(yuǎn)處復(fù)制到本地
scp -r root@192.168.120.204:/opt/soft/mongodb /opt/soft/
從192.168.120.204機(jī)器上的/opt/soft/中下載mongodb 目錄到本地的/opt/soft/目錄來。
例子 3 : 上傳本地文件到遠(yuǎn)程機(jī)器指定目錄
scp /opt/soft/nginx-0.5.38.tar.gz root@192.168.120.204:/opt/soft/scptest
復(fù)制本地opt/soft/目錄下的文件nginx-0.5.38.tar.gz 到遠(yuǎn)程機(jī)器192.168.120.204的opt/soft/scptest目錄
例子 4 : 上傳本地目錄到遠(yuǎn)程機(jī)器指定目錄
scp -r /opt/soft/mongodb root@192.168.120.204:/opt/soft/scptes
上傳本地目錄 /opt/soft/mongodb到遠(yuǎn)程機(jī)器192.168.120.204上/opt/soft/scptest的目錄中去
例子 5 : 從遠(yuǎn)處目錄到本地指定目錄 + ssh key
A機(jī)器無密登錄 B 機(jī)器的操作: ssh root@ipAddress
2臺(tái)機(jī)器 A 本地 B 遠(yuǎn)程:
In A機(jī)器:
1.yum install ssh
2.ssh-keygen -t rsa -C "472023527@qq.com"
3.cat ~/.ssh/id_rsa.pub // id_rsa是私鑰
將這個(gè)公鑰給機(jī)器 B 中
In B機(jī)器:
進(jìn)入/root/.ssh/目錄中 將 A 機(jī)器的公鑰給復(fù)制到 B 器文件 : sam.pub
然后執(zhí)行指令:
>> cat sam.pub >> /root/.ssh/authorized_keys (將id_rsa.pub的內(nèi)容追加到authorized_keys 中)
接下來就可以執(zhí)行 scp 的操作了:
scp -r root@192.168.120.204:/opt/soft/mongodb /opt/soft/
參考文章
附上
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。