Linux之scp命令的使用


Linux之scp命令的使用

1. scp簡介

1.1 命令功能:

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

格式為:scp [可選參數] file_source file_target

1.2 命令參數

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

2. 命令實踐

主機名 IP地址 備注
web01 192.168.200.28 測試服務器(一)
web02 192.168.200.29 測試服務器(二)

2.1 將本機文件復制到遠程服務器上

[root@web01 ~]# scp -r /root/test root@192.168.200.29:/tmp/

#命令詳解:
/root            本地文件的絕對路徑
test             要復制到服務器上的本地文件
root             通過root用戶登錄到遠程服務器(也可以使用其他擁有同等權限的用戶)
192.168.200.29   遠程服務器的ip地址(也可以使用域名或機器名)
/tmp             將本地文件復制到位於遠程服務器上的路徑

2.2 將遠程服務器上的文件復制到本機

[root@web01 ~]# scp -r root@192.168.200.29:/tmp/test /root/sc/

#命令詳解:
root             通過root用戶登錄到遠程服務器(也可以使用其他擁有同等權限的用戶)
192.168.200.29   遠程服務器的ip地址(也可以使用域名或機器名)
/tmp/test        欲復制到本機的位於遠程服務器上的文件 
/root/sc/        將遠程文件復制到本地的絕對路徑

2.3 如果遠程服務器防火牆有特殊限制,scp便要走特殊端口,具體用什么端口視情況而定,命令格式如下:

[root@web01 ~]# scp -rP 1234 /root/test root@192.168.200.29:/tmp/

2.4 scp命令延申

#對拷文件夾 (包括文件夾本身)
[root@web01 ~]# scp -r /root/sc root@192.168.200.29:/tmp/
#對拷文件夾下所有文件 (不包括文件夾本身)
[root@web01 ~]# scp -r /root/sc/* root@192.168.200.29:/tmp/
#對拷文件並重命名
[root@web01 ~]# scp -r /root/test root@192.168.200.29:/tmp/test.txt


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM