scp 用戶的 rsync 遷移指南
在 SSH 8.0 預發布公告中,OpenSSH 項目表示,他們認為 scp 協議已經過時,不靈活,而且不容易修復,然後他們繼而推薦使用 sftp
或 rsync
來進行文件傳輸。
然而,很多用戶都是從小用著 scp
命令長大的,所以對 rsync
並不熟悉。此外,rsync
可以做的事情也遠不止複製文件,這可能會給菜鳥們留下複雜和難以掌握的印象。尤其是,scp
命令的標誌大體上可以直接對應到 cp
命令的標誌,而 rsync
命令的標誌卻和它大相徑庭。
本文將為熟悉 scp
的人提供一個介紹和過渡的指南。讓我們跳進最常見的場景:複製文件和複製目錄。
複製文件
對於複製單個文件而言,scp
和 rsync
命令實際上是等價的。比方說,你需要把 foo.txt
傳到你在名為 server
的伺服器上的主目錄下:
$ scp foo.txt me@server:/home/me/
相應的 rsync
命令只需要輸入 rsync
取代 scp
:
$ rsync foo.txt me@server:/home/me/
複製目錄
對於複製目錄,就有了很大的分歧,這也解釋了為什麼 rsync
會被認為比 scp
更複雜。如果你想把 bar
目錄複製到 server
伺服器上,除了指定 ssh
信息外,相應的 scp
命令和 cp
命令一模一樣。
$ scp -r bar/ me@server:/home/me/
對於 rsync
,考慮的因素比較多,因為它是一個比較強大的工具。首先,我們來看一下最簡單的形式:
$ rsync -r bar/ me@server:/home/me/
看起來很簡單吧?對於只包含目錄和普通文件的簡單情況,這就可以了。然而,rsync
更在意發送與主機系統中一模一樣的文件。讓我們來創建一個稍微複雜一些,但並不罕見的例子:
# 創建多級目錄結構
$ mkdir -p bar/baz
# 在其根目錄下創建文件
$ touch bar/foo.txt
# 現在創建一個符號鏈接指回到該文件
$ cd bar/baz
$ ln -s ../foo.txt link.txt
# 返回原位置
$ cd -
現在我們有了一個如下的目錄樹:
bar
├── baz
│ └── link.txt -> ../foo.txt
└── foo.txt
1 directory, 2 files
如果我們嘗試上面的命令來複制 bar
,我們會注意到非常不同的(並令人驚訝的)結果。首先,我們來試試 scp
:
$ scp -r bar/ me@server:/home/me/
如果你 ssh
進入你的伺服器,看看 bar
的目錄樹,你會發現它和你的主機系統有一個重要而微妙的區別:
bar
├── baz
│ └── link.txt
└── foo.txt
1 directory, 2 files
請注意,link.txt
不再是一個符號鏈接,它現在是一個 foo.txt
的完整副本。如果你習慣於使用 cp
,這可能會是令人驚訝的行為。如果你嘗試使用 cp -r
複製 bar
目錄,你會得到一個新的目錄,裡面的符號鏈接和 bar
的一樣。現在如果我們嘗試使用之前的 rsync
命令,我們會得到一個警告:
$ rsync -r bar/ me@server:/home/me/
skipping non-regular file "bar/baz/link.txt"
rsync
警告我們它發現了一個非常規文件,並正在跳過它。因為你沒有告訴它可以複製符號鏈接,所以它忽略了它們。rsync
在手冊中有一節「符號鏈接」,解釋了所有可能的行為選項。在我們的例子中,我們需要添加 -links
標誌:
$ rsync -r --links bar/ me@server:/home/me/
在遠程伺服器上,我們看到這個符號鏈接是作為一個符號鏈接複製過來的。請注意,這與 scp
複製符號鏈接的方式不同。
bar/
├── baz
│ └── link.txt -> ../foo.txt
└── foo.txt
1 directory, 2 files
為了省去一些打字工作,並利用更多的文件保護選項,在複製目錄時可以使用歸檔標誌 -archive
(簡稱 -a
)。該歸檔標誌將做大多數人所期望的事情,因為它可以實現遞歸複製、符號鏈接複製和許多其他選項。
$ rsync -a bar/ me@server:/home/me/
如果你感興趣的話,rsync
手冊頁有關於存檔標誌的深入解釋。
注意事項
不過,使用 rsync
有一個注意事項。使用 scp
比使用 rsync
更容易指定一個非標準的 ssh 埠。例如,如果 server
使用 8022 埠的 SSH 連接,那麼這些命令就會像這樣:
$ scp -P 8022 foo.txt me@server:/home/me/
而在使用 rsync
時,你必須指定要使用的「遠程 shell」命令,默認是 ssh
。你可以使用 -e
標誌來指定。
$ rsync -e 'ssh -p 8022' foo.txt me@server:/home/me/
rsync
會使用你的 ssh
配置;但是,如果你經常連接到這個伺服器,你可以在你的 ~/.ssh/config
文件中添加以下代碼。這樣你就不需要再為 rsync
或 ssh
命令指定埠了!
Host server
Port 8022
另外,如果你連接的每一台伺服器都在同一個非標準埠上運行,你還可以配置 RSYNC_RSH
環境變數。
為什麼你還是應該切換到 rsync?
現在我們已經介紹了從 scp
切換到 rsync
的日常使用案例和注意事項,讓我們花一些時間來探討一下為什麼你可能想要使用 rsync
的優點。很多人在很久以前就已經開始使用 rsync
了,就是因為這些優點。
即時壓縮
如果你和伺服器之間的網路連接速度較慢或有限,rsync
可以花費更多的 CPU 處理能力來節省網路帶寬。它通過在發送數據之前對數據進行即時壓縮來實現。壓縮可以用 -z
標誌來啟用。
差量傳輸
rsync
也只在目標文件與源文件不同的情況下複製文件。這可以在目錄中遞歸地工作。例如,如果你拿我們上面的最後一個 bar
的例子,並多次重新運行那個 rsync
命令,那麼在最初的傳輸之後就不會有任何傳輸。如果你知道你會重複使用這些命令,例如備份到 U 盤,那麼使用 rsync
即使是進行本地複製也是值得的,因為這個功能可以節省處理大型數據集的大量的時間。
同步
顧名思義,rsync
可以做的不僅僅是複製數據。到目前為止,我們只演示了如何使用 rsync
複製文件。如果你想讓 rsync
把目標目錄變成源目錄的樣子,你可以在 rsync
中添加刪除標誌 -delete
。這個刪除標誌使得 rsync
將從源目錄中複製不存在於目標目錄中的文件,然後它將刪除目標目錄中不存在於源目錄中的文件。結果就是目標目錄和源目錄完全一樣。相比之下,scp
只會在目標目錄下添加文件。
結論
對於簡單的使用情況,rsync
並不比老牌的 scp
工具複雜多少。唯一顯著的區別是在遞歸複製目錄時使用 -a
而不是 -r
。然而,正如我們看到的,rsync
的 -a
標誌比 scp
的 -r
標誌更像 cp
的 -r
標誌。
希望通過這些新命令,你可以加快你的文件傳輸工作流程。
via: https://fedoramagazine.org/scp-users-migration-guide-to-rsync/
作者:chasinglogic 選題:lujun9972 譯者:wxy 校對:wxy
本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive