每天學(xué)習(xí)一個(gè) Linux 指令 : scp

每天學(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ù)

  • 參數(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ù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容