主頁 > 知識庫 > Linux服務器間文件實時同步的實現(xiàn)

Linux服務器間文件實時同步的實現(xiàn)

熱門標簽:安陽ai電銷機器人軟件 柳州市機器人外呼系統(tǒng)報價 云會外呼系統(tǒng) 涪陵商都400電話開通辦理 申請400電話價格多少 外呼系統(tǒng)的經(jīng)營范圍 廈門營銷外呼系統(tǒng)平臺 智能電話機器人坐席 外呼系統(tǒng)不彈窗

使用場景

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

數(shù)據(jù)鏡像備份工具Rsync

Rsync是一個非??焖俸挽`活的文件復制工具。它支持本機或者是和遠程服務器間的文件復制。Rsync使用了delta-transfer算法,它只需要傳送源端和目標端的文件差異部分,大大減少了網(wǎng)絡帶寬的消耗和復制耗費的時間。Rsync多用于數(shù)據(jù)備份和鏡像。

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

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

Rsync的安裝與操作

安裝Rsync

分別在服務器A和服務器B的terminal執(zhí)行:

sudo yum install rsync

安裝完畢后,會發(fā)現(xiàn)rsync的配置文件位于 etc/rsyncd.conf 。該文件使用daemon方式同步時需要使用,此處暫不介紹。

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

服務器A執(zhí)行:

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

創(chuàng)建源端目錄和目標端目錄

在服務器A中:

mkdir /home/paul/rsync

在服務器B中:

mkdir /home/paul/rsync

在服務器A創(chuàng)建測試文件

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

執(zhí)行文件傳送命令

在服務器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

會發(fā)現(xiàn)在demo.txt也出現(xiàn)在了服務器B中/home/paul/rsync目錄。

命令解析:

(1) 將服務器A中的/home/paul/rsync目錄內(nèi)的文件復制到服務器B(192.168.100.130)的/home.paul/rsync中。

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

Rsync存在的問題

Rsync僅是一個文件復制工具,它無法對源端文件的增刪改操作進行監(jiān)聽。在源端做出更改后,需要執(zhí)行rsync命令才能將變更同步到目標端。

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

文件系統(tǒng)事件監(jiān)聽工具inotify

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

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

inotify-tools的安裝

對于centos7系統(tǒng),依次執(zhí)行:

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

使用inotifywait命令進行事件監(jiān)聽

監(jiān)聽腳本如下(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

參數(shù)解析

  • -m 保持持續(xù)監(jiān)聽狀態(tài),如果不寫該參數(shù),inotifywait會在監(jiān)聽到一次事件之后退出。
  • -r 遞歸方式監(jiān)聽目錄。
  • -q 安靜模式,打印輸出較少的內(nèi)容。
  • --timefmt 指定時間的輸出格式。
  • --format 指定事件輸出的格式。
  • -e 設置監(jiān)聽的事件類型。這里監(jiān)聽增刪改和metadata的變更。

對于每次觸發(fā)的監(jiān)聽時間,inotifywait會執(zhí)行do和done之間的代碼。在這里,我們調(diào)用之前所說的rsync命令進行文件同步。

監(jiān)聽腳本加入crontab

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

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

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:南充 晉城 福州 孝感 綏化 蕪湖 巴中 撫順

巨人網(wǎng)絡通訊聲明:本文標題《Linux服務器間文件實時同步的實現(xiàn)》,本文關鍵詞  Linux,服務器,間,文件,實時,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Linux服務器間文件實時同步的實現(xiàn)》相關的同類信息!
  • 本頁收集關于Linux服務器間文件實時同步的實現(xiàn)的相關信息資訊供網(wǎng)民參考!
  • 推薦文章