Linux服務器間文件實時同步的實現

使用場景

現有服務器A和服務器B,如果服務器A的指定目錄(例如 /home/paul/rsync/ )中的內容發生變更(增刪改和屬性變更),實時將這些變更同步到服務器B的目標目錄中(例如 /home/paul/rsync/ )。

數據鏡像備份工具Rsync

Rsync是一個非常快速和靈活的文件複製工具。它支持本機或者是和遠程服務器間的文件複製。Rsync使用了delta-transfer算法,它只需要傳送源端和目標端的文件差異部分,大大減少了網絡帶寬的消耗和複製耗費的時間。Rsync多用於數據備份和鏡像。

Rsync使用了快速檢查算法,通過比較文件大小或最後修改時間的變化來判斷文件是否需要同步。

Rsync連接遠程主機有兩種方式:使用ssh或rsync daemon。這裏使用Rsync方式來實現遠程文件備份。

Rsync的安裝與操作

安裝Rsync

分別在服務器A和服務器B的terminal執行:

sudo yum install rsync

安裝完畢後,會發現rsync的配置文件位於 etc/rsyncd.conf 。該文件使用daemon方式同步時需要使用,此處暫不介紹。

配置服務器A和B之間的免密登錄

服務器A執行:

ssh-keygen
ssh-copy-id 服務器B的IP地址

創建源端目錄和目標端目錄

在服務器A中:

mkdir /home/paul/rsync

在服務器B中:

mkdir /home/paul/rsync

在服務器A創建測試文件

echo "Hello from Server A" >> /home/paul/rsync/demo.txt

執行文件傳送命令

在服務器A運行:

# (1)
rsync -avPz --progress /home/paul/rsync 192.168.100.130:/home.paul/rsync
# (2)
rsync -avPz --delete --progress /home/paul/rsync 192.168.100.130:/home.paul/rsync

會發現在demo.txt也出現在了服務器B中/home/paul/rsync目錄。

命令解析:

(1) 將服務器A中的/home/paul/rsync目錄內的文件複製到服務器B(192.168.100.130)的/home.paul/rsync中。

(2) 比較目標端和源端的文件,如果目標端的文件在源端不存在,在目標端刪除該文件。

Rsync存在的問題

Rsync僅是一個文件複製工具,它無法對源端文件的增刪改操作進行監聽。在源端做出更改後,需要執行rsync命令才能將變更同步到目標端。

Rsync在每次同步前需要掃描整個目錄。如果源目錄內的文件數量比較多,掃描可能需要耗費較多的時間。
爲了滿足實時監聽的要求,我們需要引入另一個工具:inotify。

文件系統事件監聽工具inotify

inotify-tools爲inotify提供一個簡單接口。它是一個c語言編寫的庫,同時也包含命令行工具。

inotify-tools的詳細介紹請點擊: https://github.com/rvoicilas/inotify-tools/wiki

inotify-tools的安裝

對於centos7系統,依次執行:

yum install -y epel-release
yum --enablerepo=epel install inotify-tools

使用inotifywait命令進行事件監聽

監聽腳本如下(inotifywait-rsync.sh):

inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f' -e modify,delete,create,attrib /home/paul/rsync/ | while read file
do
rsync -avPz --progress /home/paul/rsync/ 192.168.100.130:/home/paul/rsync/
rsync -avPz --delete /home/paul/rsync/ 192.168.100.130:/home/paul/rsync/
echo "${file} was synchronized"
done

參數解析

  • -m 保持持續監聽狀態,如果不寫該參數,inotifywait會在監聽到一次事件之後退出。

  • -r 遞歸方式監聽目錄。

  • -q 安靜模式,打印輸出較少的內容。

  • --timefmt 指定時間的輸出格式。

  • --format 指定事件輸出的格式。

  • -e 設置監聽的事件類型。這裏監聽增刪改和metadata的變更。

對於每次觸發的監聽時間,inotifywait會執行do和done之間的代碼。在這裏,我們調用之前所說的rsync命令進行文件同步。

監聽腳本加入crontab

crontab -e
* * * * * sh /home/paul/inotifywait-rsync.sh

參考資料
https://rsync.samba.org
https://github.com/rvoicilas/inotify-tools/wiki

您可能感興趣的文章:

文章同步發佈: https://www.geek-share.com/detail/2755097834.html

參考文章:


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