在開發中經常遇到這樣的場景,就是兩台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-tw/n/252273.html
微信掃一掃
支付寶掃一掃