溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

inotify +rsync 實時同步

發(fā)布時間:2020-07-12 07:33:43 來源:網(wǎng)絡(luò) 閱讀:428 作者:菜鳥東哥 欄目:建站服務(wù)器

1.1 inotify簡介

inotify是一種強大的,細粒度的,異步的文件系統(tǒng)時間監(jiān)控機制,Linux內(nèi)核從2.6.13加入了inotify支持,通過inotify可以監(jiān)控文件系統(tǒng)匯中添加,刪除,修改,移動等各種事件,利用這個內(nèi)核接口,第三方軟件就可以監(jiān)控文件系統(tǒng)下文件的各種變化情況,而inotify-tools正式實施這樣的監(jiān)控的軟件,國人周洋在金山公司開發(fā)了類似的實時同步軟件sersync.

 

1.1.1 安裝inotify

在安裝inotify-tools前請先確認你的Linux內(nèi)核是否達到了2.6.13,并且在編輯時開啟CONFIG_INOTIFY選項,也可以通過以下命令檢測。

安裝inotify默認條件:

  • yum安裝方式源信息必須設(shè)置正確:

默認的yum源(軟件的倉庫):base+extras+updates

國內(nèi)yum源(軟件的倉庫):http://mirrors.aliyun.com/help/centos

擴展yum源(擴展的倉庫):epel(企業(yè)級Linuxyum源的擴展倉庫)

  • 阿里云epel源:通過訪問阿里yum源鏡像地址獲取

  • 直接安裝epel源方式:yum install epel-release

 

 

 

1.2 數(shù)據(jù)同步原理介紹

1.2.1 inotify+rsync實時同步

                           

  • 實時同步軟件會負責(zé)監(jiān)控磁盤文件系統(tǒng)的變化。比如:指定一個/data目錄,實時同步軟件服務(wù)進程會實時監(jiān)控這個/data目錄中數(shù)據(jù)的變化,即文件系統(tǒng)blockinode信息的變化。

  • 實時同步軟件服務(wù)進程監(jiān)控/data目錄文件系統(tǒng)數(shù)據(jù)一旦發(fā)生變化,就會執(zhí)行rsync命令,將變化的文件數(shù)據(jù)信息推送到備份服務(wù)器相應(yīng)的備份目錄中,從而完成數(shù)據(jù)的實時備份。

rsync的傳輸效率是很高的但rsync也有缺點,最大的問題就是每次執(zhí)行rsync命令都會遍歷目標目錄,當文件不多時,這沒什么問題,一旦文件數(shù)到了一定規(guī)模,那么每次遍歷都會消耗很多資源,如果只對經(jīng)常改動的目錄進行同步,也可以忽略這個問題,如果每次改動的目錄多較大,那么就要用到inotify了。

inotify+rsync的方式使得效率更高效,只對經(jīng)常改變的文件進行同步

安裝 inotify 軟件的前提 rsync 服務(wù)安裝成功,可以在客戶端推送拉取數(shù)據(jù)

另外:inotify 是在客戶端配置安裝的軟件,別裝錯了

 

 

1.2.2 定時任務(wù)crond+rsync數(shù)據(jù)同步

rsync+定時任務(wù)的方式會定時的將系統(tǒng)中變動的文件定時的同步給服務(wù)器,但是定時任務(wù)的最小單位是分。這對于數(shù)據(jù)變化快而且數(shù)據(jù)重要的金融行業(yè)來說,顯然是不能容忍的。因此這種方式有一定局限性。

1.3 inotify知識介紹

1.3.1 inotify軟件的主要工具命令

[root@nfs01 ~]# rpm-ql inotify-tools     ##查詢inotify-tools中包含哪些包

/usr/bin/inotifywait

/usr/bin/inotifywatch

/usr/lib64/libinotifytools.so.0

/usr/lib64/libinotifytools.so.0.4.1

/usr/share/doc/inotify-tools-3.14

/usr/share/doc/inotify-tools-3.14/AUTHORS

/usr/share/doc/inotify-tools-3.14/COPYING

/usr/share/doc/inotify-tools-3.14/ChangeLog

/usr/share/doc/inotify-tools-3.14/NEWS

/usr/share/doc/inotify-tools-3.14/README

/usr/share/man/man1/inotifywait.1.gz

/usr/share/man/man1/inotifywatch.1.gz

[root@nfs01 ~]#

  • inotifywait:在被監(jiān)控的文件或目錄上等待特定文件系統(tǒng)時間(open close delete等)發(fā)生,執(zhí)行后處于阻塞狀態(tài),適合在shell腳本中使用。

  • inotifywatch:收集被監(jiān)控的文件系統(tǒng)使用度統(tǒng)計數(shù)據(jù),指文件系統(tǒng)事件發(fā)生的次數(shù)統(tǒng)計。

說明:yum安裝后可以直接使用,如果編譯安裝需要進入到相應(yīng)軟件目錄的bin目錄下使用。

1.3.2 查看當前系統(tǒng)是否支持inotify

[root@nfs01 etc]# uname -r

2.6.32-642.el6.x86_64

[root@nfs01 etc]# ls -l /proc/sys

sys/           sysrq-trigger  sysvipc/      

[root@nfs01 etc]# ls-l /proc/sys/fs/inotify/

total 0

-rw-r--r-- 1 root root 0 May 12 16:26 max_queued_events

-rw-r--r-- 1 root root 0 May 12 16:26 max_user_instances

-rw-r--r-- 1 root root 0 May 12 16:26 max_user_watches

[root@nfs01 etc]#顯示上面三個文件說明支持inotify

[root@nfs01 ~]# cd/proc/sys/fs/inotify/

[root@nfs01 inotify]# ls

max_queued_events  max_user_instances  max_user_watches

[root@nfs01 inotify]# catmax_user_watches

8192

[root@nfs01 inotify]# catmax_user_instances

128

[root@nfs01 inotify]# catmax_queued_events

16384

[root@nfs01 inotify]#

 

關(guān)鍵參數(shù)說明:

max_queued_events:設(shè)置inotify實例事件(event)隊列可容納的事件數(shù)量。

max_user_instances:設(shè)置每個用戶可以運行的inotifywaitinotifywatch命令的進程數(shù)。

max_user_watches:設(shè)置inotifywaitinotifywatch命令可以監(jiān)視的文件數(shù)量(單進程)

1.3.3 inotify的工作機制(屬于觸發(fā)機制)

  • 客戶端開啟運行inotify服務(wù)進程,檢測共享目錄的數(shù)據(jù)變化

  • 獲取到共享目錄數(shù)據(jù)發(fā)生變化,通知執(zhí)行rsync命令同步數(shù)據(jù)。

  • 將變化數(shù)據(jù)發(fā)送到rsync服務(wù)端(開啟rsync守護進程服務(wù)器)的共享目錄中。

 

 

 

 

 

 

1.3.4 inotify同步命令詳解

1.3.4.1         inotify命令的參數(shù)

命令參數(shù)

參數(shù)說明

-m|--monitor

始終保持事件監(jiān)聽狀態(tài)

-d|--daemon

類似于-m參數(shù),只是將命令運行在后臺,記錄觸發(fā)的事件信息在指定文件中,利用--outfile參數(shù),定義程序日志使用--syslog參數(shù)

-r(重要參數(shù))

遞歸監(jiān)控目錄數(shù)據(jù)信息變化

-o|--outfile <file>

打印事件到文件中,相當于標準正確輸出

-s|--syslog

發(fā)送錯誤到syslog相當于標準錯誤輸出

-q|--quiet

輸出信息少(只打印事件信息)

--exclude|<pattern>

排除文件或目錄時,不區(qū)分大小寫

--timefmt <fmt>

指定事件輸出的格式

--format <fmt>

打印使用指定的輸出類似格式字符串,即實際監(jiān)控輸出的內(nèi)容。

-e

指定監(jiān)聽指定的事件,如果省略,表示所有事件都進行監(jiān)聽

通過/usr/local/inotify-tools/bin/inotifywait --help命令獲取監(jiān)控事件信息。

1.3.4.2         inotify的事件

事件名稱

事件說明

access

文件或目錄內(nèi)容被讀取

modify

文件或目錄內(nèi)容被寫入

attrib

文件或目錄屬性改變

close_write

文件或目錄關(guān)閉,在寫入模式打開之后關(guān)閉的。

close_nowrite

文件或目錄關(guān)閉,在只讀模式打開之后關(guān)閉的。

close

文件或目錄關(guān)閉,不管讀或是寫模式

open

文件或目錄被打開

moved_to

文件或目錄被移動到監(jiān)控的目錄中

moved_from

文件或目錄被移動從監(jiān)控的目錄中。

move

文件或目錄不管移動到或移動出監(jiān)控目錄都觸發(fā)事件

create

文件或目錄創(chuàng)建在監(jiān)控的目錄中。

delete

文件或目錄被刪除在監(jiān)控的目錄中

delete_self

文件或目錄被刪除

unmount

文件系統(tǒng)包含的文件或目錄不能卸載

 

1.4 部署rsync+inotify過程

1.4.1 部署rsync守護進程模式(一)

部署rsync守護進程模式

   服務(wù)端的配置

   01:檢查是否安裝rsync

   02:配置rsyncd.conf配置文件

   03:創(chuàng)建rsync進程管理用戶

   04:創(chuàng)建模塊的存儲目錄

   05:修改存儲目錄的屬主和屬組權(quán)限

   06:配置認證密碼文件,授權(quán)為600權(quán)限

   07:啟動rsync守護進程服務(wù)

   08:設(shè)置rsync服務(wù)開機自啟動

   09:進行測試

   

   客戶端的配置

   01:創(chuàng)建密碼文件,并授權(quán)600權(quán)限

   02:客戶端進行測試

服務(wù)端代碼文件:

[root@backup nfsbackup]# vim/etc/rsyncd.conf

(省略部分內(nèi)容)

[backup]                               ##模塊名稱

path = /backup

[nfsbackup]                               ##創(chuàng)建一個模塊

path = /nfsbackup

"/etc/rsyncd.conf" 20L,474C written    

創(chuàng)建備份模塊

[root@backup ~]# mkdir /nfsbackup

授權(quán)屬主屬組

[root@backup ~]# chown -R rsync.rsync/nfsbackup/

查看授權(quán)情況

[root@backup ~]# ll -d /nfsbackup/

drwxr-xr-x 2 rsync rsync 4096 May 1109:22 /nfsbackup/

查看密碼文件

[root@backup ~]# cat/etc/rsync.password

rsync_backup:123456

查看密碼文件權(quán)限是否為600

[root@backup ~]# ll/etc/rsync.password

-rw------- 1 root root 20 May  4 17:51 /etc/rsync.password

[root@backup ~]#

[root@backup ~]# /etc/init.d/xinetdstatus

xinetd (pid  1810) is running...

[root@backup ~]# /etc/init.d/xinetdstop

Stopping xinetd:                                         [  OK  ]

[root@backup ~]# rsync --daemon

[root@backup ~]# ps -ef |grep rsync

root       4955     1  0 09:25 ?        00:00:00 rsync --daemon

root       4959  4860  0 09:25 pts/0    00:00:00 grep rsync

[root@backup ~]#

1.4.2 安裝部署inotify(二)

1.4.2.1         手工測試inotify軟件監(jiān)控事件

打開兩個相同的xshell窗口測試,在其中一個窗口輸入下面代碼:

[root@nfs01 data]# inotifywait-mrq /data/

/data/ DELETE oldboy.txt

/data/ CREATE oldboy.txt

/data/ OPEN oldboy.txt

/data/ ATTRIB oldboy.txt

/data/ CLOSE_WRITE,CLOSE oldboy.txt

在另外一個相同的窗口進行操作,如創(chuàng)建,刪除,移動等。觀察變化。

  • 測試create 事件

NFS服務(wù)器上開啟inotify相應(yīng)的監(jiān)控功能,并輸出信息

[root@nfs01 backup]#inotifywait -mqr --timefmt '%d/%y %H:%M' --format '%T %w%f' -e create /backup                   ###監(jiān)控backup創(chuàng)建事件顯示信息

12/17 23:18 /backup/oldbpy.txt

 

再開啟一個NFS服務(wù)器連接窗口進行測試驗證create事件。

[root@nfs01 backup]# ls

m

[root@nfs01 backup]# mkdir oldbpy.txt

[root@nfs01 backup]# ls

m oldbpy.txt

[root@nfs01 backup]# rm oldbpy.txt/-fr

[root@nfs01 backup]#

說明:只監(jiān)控create創(chuàng)建事件,其他事件沒有進行監(jiān)控,其他事件產(chǎn)生,監(jiān)控服務(wù)沒有信息輸出。

 

可以簡化命令和輸出信息:

[root@nfs01 backup]# inotifywait -mqr --format '%w%f' -e create /backup

/backup/1.txt                           監(jiān)控/backup目錄創(chuàng)建事件顯示信息。

/backup/2.txt

/backup/3.txt

/backup/4.txt

/backup/5.txt

 

再開啟一個NFS服務(wù)器連接窗口進行測試驗證create事件。

[root@nfs01 backup]# mkdir {1..5}.txt

[root@nfs01 backup]# ls

1.txt 2.txt  3.txt  4.txt 5.txt  m

[root@nfs01 backup]# rm 3.txt/ -fr                ##刪除事件沒有監(jiān)控,另一端也沒有信息輸出。

[root@nfs01 backup]# ls

1.txt 2.txt  4.txt  5.txt m

[root@nfs01 backup]#

  • 測試delete事件

NFS服務(wù)器上開啟inotify相應(yīng)的監(jiān)控功能,并輸出信息

[root@nfs01 backup]# ls

1.txt 2.txt  4.txt  5.txt m

[root@nfs01 backup]# rm -fr 5.txt/            ##刪除文件測試

[root@nfs01 backup]# rm -fr 2.txt/

 [root@nfs01 backup]# mkdir oldboy.txt           ###創(chuàng)建文件測試,但是沒有信息輸出

[root@nfs01 backup]#

再開啟一個NFS服務(wù)器連接窗口進行測試驗證delete事件

[root@nfs01 backup]# inotifywait-mqr  --format '%w%f' -e delete /backup

/backup/5.txt

/backup/2.txt                  ##刪除會有信息輸出

  • 測試moved事件

NFS服務(wù)器上開啟inotify相應(yīng)的監(jiān)控功能,并輸出信息

[root@nfs01 backup]# inotifywait-mqr  --format '%w%f' -e move /backup

/backup/oldboy.txt

/backup/1.txt

 

再開啟一個NFS服務(wù)器連接窗口進行測試驗證move事件

[root@nfs01 backup]# ls

1.txt 4.txt  m

[root@nfs01 backup]# mv oldboy.txt//tmp/

[root@nfs01 backup]# mkdir 4

[root@nfs01 backup]# rm 4.txt/ -fr

[root@nfs01 backup]# mv 1.txt/ /tmp/

[root@nfs01 backup]#

說明:只監(jiān)控move移動事件,其他事件并沒有進行監(jiān)控,其他事件產(chǎn)生,監(jiān)控服務(wù)沒有信息輸出,因此利用監(jiān)控移動事件,就對目錄中文件或目錄的移入和移出事件都監(jiān)控了。

知識點結(jié)論:

通過上面的測試實驗可以發(fā)現(xiàn),有些監(jiān)控事件已經(jīng)包含了其他相應(yīng)事件的監(jiān)控功能,因此進行監(jiān)控時可以根據(jù)要求精簡相應(yīng)的監(jiān)控事件。

重要事件

包含事件

備注說明

close

close_write , close_nowrite

文件或目錄關(guān)閉,不管讀寫或是寫模式;即包含寫關(guān)閉或讀關(guān)閉

close_write

create

包含文件創(chuàng)建事件,但不包含目錄創(chuàng)建事件

move

move_to  move_from

文件或目錄不管移動到或移動出監(jiān)控目錄都觸發(fā)事件,即包含信息移入或移除監(jiān)控目錄事件。

重要參數(shù)匯總:根據(jù)以上說明,在實際使用時,只要監(jiān)控以下事件即可:create創(chuàng)建,delete刪除,moved_to移入,close_write修改

1.4.2.2         rsync+inotify利用腳本進行結(jié)合

需要通過相應(yīng)腳本實現(xiàn)目錄中變化文件信息推送,腳本編寫思路演變過程如下:

  • 環(huán)境準備:在服務(wù)器上添加nfsbackup模塊和nfsbackup目錄,并授權(quán)屬組和屬主。

[root@backup nfsbackup]# cat/etc/rsyncd.conf

tart##

uid = rsync

gid = rsync

use chroot = no

max connections = 200

timeout = 300

pid file = /var/run/rsyncd.pid

lock file = /var/run/rsync.lock

log file = /var/log/rsyncd.log

ignore errors

read only = false

list = false

hosts allow = 172.16.1.0/24

hosts deny = 0.0.0.0/32

auth users = rsync_backup

secrets file = /etc/rsync.password

[backup]                               ##模塊名稱

path = /backup

[nfsbackup]                               ##模塊名稱

path = /nfsbackup

[root@backup nfsbackup]#

[root@backup backup]# chown rsync.rsync /nfsbackup/

  • 客戶端上編寫腳本實時監(jiān)控目錄中信息變化,并獲取變化信息。

# 第一步:編寫監(jiān)控命令

 

#!/bin/bash

#desc: monitor /data and pushdatainfo to backup_server

/usr/bin/inotifywait -mrq --format"%w%f" -e moved_to,delete,create,close_write /data|\

第二步:編寫腳本編寫推送命令rsync 進行無差異同步 --delete /data/

while read line

do

rsync -az --delete /data/rsync_backup@172.16.1.41::nfsbackup --password-file=/etc/rsync.password

done

  • 實現(xiàn)腳本監(jiān)控目錄信息事件,并讓腳本在后臺運行。

[root@nfs01 data]# sh/server/scripts/monitor.sh &>/dev/null &

[1] 9891

[root@nfs01 data]#


1.5 inotify的優(yōu)缺點介紹

  • 監(jiān)控文件系統(tǒng)事件變化,通過同步工具實現(xiàn)實時數(shù)據(jù)同步。

  • 并發(fā)如果大于200個文件(4-100k),同步就會有延遲。

  • 前面寫的腳本,每次都是全部推送一次,但確實是增量的,也可以只同步變化的文件,不變化的不理。

  • 監(jiān)控到事件后,請用rsync同步是單進程的(加&并發(fā)),sersync是多進程同步。

  • inotify服務(wù)優(yōu)化

[root@nfs01 etc]# ls-l /proc/sys/fs/inotify/

total 0

-rw-r--r-- 1 root root 0 May 12 16:26 max_queued_events

-rw-r--r-- 1 root root 0 May 12 16:26 max_user_instances

-rw-r--r-- 1 root root 0 May 12 16:26 max_user_watches

[root@nfs01 inotify]# catmax_user_watches

8192

[root@nfs01 inotify]# catmax_user_instances

128

[root@nfs01 inotify]# cat max_queued_events

16384

[root@nfs01 inotify]#

[root@nfs01 data]# cd/proc/sys/fs/inotify/

[root@nfs01 inotify]# ls

max_queued_events  max_user_instances  max_user_watches

[root@nfs01 inotify]# echo "50000000">/proc/sys/fs/inotify/max_user_watches

[root@nfs01 inotify]# echo "50000000">/proc/sys/fs/inotify/max_queued_events

[root@nfs01 inotify]# ##說明:以上配置重啟可能會失效,需要放置在rc.local文件中。

 


向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI