linux scp(Linux之間複製文件和目錄)命令參數及用法詳解

一般情況,本地網絡跟遠程網絡進行數據交抱,或者數據遷移,常用的有三種方法,一是ftp,二是wget /fetch 三是,rsync 大型數據遷移用rysync,其次用fetch/wget ,最次是ftp,最慢是ftp.這幾天,在忙數據遷移時,用到ssh的scp方法來遷移數據。速度與效果都很好。特別是現在許多服務器爲了安全,都會改ssh默認的22端口,改成一個特殊的端口。所以。在scp或者sftp時,就要指定通過什麼端口來遷移。現在,特記下這個特殊端口來scp的命令

Linux scp命令用於Linux之間複製文件和目錄,具體如何使用這裏好好介紹一下,從本地複製到遠程、從遠程複製到本地是兩種使用方式。這裏有具體舉例:

==================

Linux scp 命令

==================

scp 可以在 2個 linux 主機間複製文件;

命令基本格式:

scp [可選參數] file_source file_target

======

從 本地 複製到 遠程

======

* 複製文件:

* 命令格式:

scp local_file remote_username@remote_ip:remote_folder

或者

scp local_file remote_username@remote_ip:remote_file

或者

scp local_file remote_ip:remote_folder

或者

scp local_file remote_ip:remote_file

第1,2個指定了用戶名,命令執行後需要再輸入密碼,第1個僅指定了遠程的目錄,文件名字不變,第2個指定了文件名;

第3,4個沒有指定用戶名,命令執行後需要輸入用戶名和密碼,第3個僅指定了遠程的目錄,文件名字不變,第4個指定了文件名;

* 例子:

scp /home/space/music/1.mp3 [email protected]du.cn:/home/root/others/music

scp /home/space/music/1.mp3 [email protected]:/home/root/others/music/001.mp3

scp /home/space/music/1.mp3 www.cumt.edu.cn:/home/root/others/music

scp /home/space/music/1.mp3 www.cumt.edu.cn:/home/root/others/music/001.mp3

* 複製目錄:

* 命令格式:

scp -r local_folder remote_username@remote_ip:remote_folder

或者

scp -r local_folder remote_ip:remote_folder

第1個指定了用戶名,命令執行後需要再輸入密碼;

第2個沒有指定用戶名,命令執行後需要輸入用戶名和密碼;

* 例子:

scp -r /home/space/music/ [email protected]:/home/root/others/

scp -r /home/space/music/ www.cumt.edu.cn:/home/root/others/

上面 命令 將 本地 music 目錄 複製 到 遠程 others 目錄下,即複製後有 遠程 有 ../others/music/ 目錄

======

從 遠程 複製到 本地

======

從 遠程 複製到 本地,只要將 從 本地 複製到 遠程 的命令 的 後2個參數 調換順序 即可;

例如:

scp [email protected]:/home/root/others/music /home/space/music/1.mp3

scp -r www.cumt.edu.cn:/home/root/others/ /home/space/music/

最簡單的應用如下 :

scp 本地用戶名 @IP 地址 : 文件名 1 遠程用戶名 @IP 地址 : 文件名 2

[ 本地用戶名 @IP 地址 :] 可以不輸入 , 可能需要輸入遠程用戶名所對應的密碼 .

可能有用的幾個參數 :

-v 和大多數 linux 命令中的 -v 意思一樣 , 用來顯示進度 . 可以用來查看連接 , 認證 , 或是配置錯誤 .

-C 使能壓縮選項 .

-P 選擇端口 . 注意 -p 已經被 rcp 使用 .

-4 強行使用 IPV4 地址 .

-6 強行使用 IPV6 地址 .

Linux scp命令的使用方法應該可以滿足大家對Linux文件和目錄的複製使用了。

關於scp的安全方面

copy 本地的檔案到遠程的機器上
scp /etc/lilo.conf [email protected]:/home/k
會將本地的 /etc/lilo.conf 這個檔案 copy 到 net67.ee.oit.edu.tw,使用者 k 的家目錄下。
copy遠程機器上的檔案到本地來
scp [email protected]:/etc/lilo.conf /etc
會將 net67.ee.oitdu.tw 中 /etc/lilo.conf 檔案 copy 到本地的 /etc 目錄下。
保持從來源 host 檔案的屬性
scp –p [email protected]:/etc/lilo.conf /etc

如果想使用特定端口 使用 scp –p(大寫) 如 scp –p 1234 [email protected]:/etc/lilo.conf /etc


在此必須注意使用者的權限是否可讀取遠程上的檔案,若想知道更多關於 scp 的使用方法,可去看看 scp 的使用手冊。
ssh-keygen
產生公開鑰 (pulib key) 和私人鑰 (private key),以保障 ssh 聯機的安性, 當 ssh 連 shd 服務器,會交換公開鑰上,系統會檢查 /etc/ssh_know_hosts 內儲存的 key,如果找到客戶端就用這個 key 產生一個隨機產生的session key 傳給服務器,兩端都用這個 key 來繼續完成 ssh 剩下來的階段。

它會產生 identity.pub、identity 兩個檔案,私人鑰存放於identity,公開鑰 存放於 identity.pub 中,接下來使用 scp 將 identity.pub copy 到遠程機器的家目錄下.ssh下的authorized_keys。 .ssh/authorized_keys(這個 authorized_keys 檔案相當於協議的 rhosts 檔案), 之後使用者能夠不用密碼去登入。RSA的認證絕對是比 rhosts 認證更來的安全可靠。
執行:
scp identity.pub [email protected]:.ssh/authorized_keys

若在使用 ssh-keygen 產生鑰匙對時沒有輸入密碼,則如上所示不需輸入密碼即可從 net67.ee.oit.edu.tw 去登入 linux1.ee.oit.edu.tw。在此,這裏輸入的密碼可以跟帳號的密碼不同,也可以不輸入密碼。


Linux下scp的用法
scp就是secure copy,一個在linux下用來進行遠程拷貝文件的命令。
有時我們需要獲得遠程服務器上的某個文件,該服務器既沒有配置ftp服務器,也沒有做共享,無法通過常規途徑獲得文件時,只需要通過簡單的scp命令便可達到目的。
一、將本機文件複製到遠程服務器上
#scp /home/administrator/news.txt [email protected]:/etc/squid
/home/administrator/ 本地文件的絕對路徑
news.txt 要複製到服務器上的本地文件
root 通過root用戶登錄到遠程服務器(也可以使用其他擁有同等權限的用戶)
192.168.6.129 遠程服務器的ip地址(也可以使用域名或機器名)
/etc/squid 將本地文件複製到位於遠程服務器上的路徑



二、將遠程服務器上的文件複製到本機
#scp [email protected]:/usr/local/sin.sh /home/administrator
remote 通過remote用戶登錄到遠程服務器(也可以使用其他擁有同等權限的用戶)
www.abc.com 遠程服務器的域名(當然也可以使用該服務器ip地址)
/usr/local/sin.sh 欲複製到本機的位於遠程服務器上的文件
/home/administrator 將遠程文件複製到本地的絕對路徑
注意兩點:
1.如果遠程服務器防火牆有特殊限制,scp便要走特殊端口,具體用什麼端口視情況而定,命令格式如下:
#scp -p 4588 [email protected]:/usr/local/sin.sh /home/administrator
2.使用scp要注意所使用的用戶是否具有可讀取遠程服務器相應文件的權限。如沒有要添加,添加讀取權限的命令如下:

chmode a+r+w 文件

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章