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