從別的服務器複製文件的步驟「linux遠程拷貝文件命令」

在開發中經常遇到這樣的場景,就是兩台Linux服務器間需要互相拷貝文件。常見的場景就是在本機通過堡壘機才能登錄到遠程的Linux服務器上,而堡壘機上沒有相應的ftp可視化工具;這時就需要藉助遠程拷貝命令。

scp就是secure copy,在linux下用來進行遠程拷貝文件的命令。有時需要獲得遠程服務器上的某個文件,該服務器既沒有配置ftp服務器,也沒有做共享,無法通過常規途徑獲得文件時,只需要通過簡單的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

參數:

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

0x01:將本機文件複製到遠程服務器上

#scp /home/oracle/news.txt root@192.168.6.129:/tmp

分析:

/home/oracle/ :本地文件的絕對路徑

news.txt :要複製到服務器上的本地文件

root:通過root用戶登錄到遠程服務器(也可以使用其他擁有同等權限的用戶)

192.168.6.129:遠程服務器的ip地址(也可以使用域名或機器名)

/tmp:將本地文件複製到位於遠程服務器上的路徑

0x02: 將遠程服務器上的文件複製到本機

#scp remote@www.itpk.com:/usr/local/sin.sh /home/oracle

remote:通過remote用戶登錄到遠程服務器(也可以使用其他擁有同等權限的用戶)

www.itpk.com:遠程服務器的域名(當然也可以使用該服務器ip地址)

/usr/local/sin.sh:欲複製到本機的位於遠程服務器上的文件

/home/oracle:將遠程文件複製到本地的絕對路徑

0x03:需要注意兩點

  • 如果遠程服務器防火牆有特殊限制,scp便要走特殊端口,具體用什麼端口視情況而定,命令格式如下:
#scp -p 4588 remote@www.itok.com:/usr/local/sin.sh /home/oracle
  • 使用scp要注意所使用的用戶是否具有可讀取遠程服務器相應文件的權限。

原創文章,作者:投稿專員,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/252273.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
投稿專員的頭像投稿專員
上一篇 2024-12-14 02:15
下一篇 2024-12-14 02:15

相關推薦

發表回復

登錄後才能評論