rsync+inotify實現實時同步web
192.168.12.22
192.168.12.25
192.168.12.22操做
rsync
rpm -aq rsync 檢測是否按照rsync
useradd rsync -s /sbin/nologin
mkdir /back
chown rsync.rsync /back/
vi /etc/rsyncd.conf算法
指定用戶
uid = rsync
gid = rsync
use chroot = no 使用更改目錄 = 不
max connections = 200 最大鏈接=200
timeout = 600 超時=600
pid file = /var/run/rsyncd.pid 進程文件位置
lock file = /var/run/rsync.lock 鎖文件位置
log file = /var/log/rsyncd.log 日誌文件位置
[back] 備份
path = /back/ 路徑= /backup/
ignore errors 忽略錯誤
read only = false 只讀=默認
list = false 名單=默認
hosts allow = 10.0.0.0/24 主機容許那個ip段訪問=10.0.0.0/24
hosts deny = 0.0.0.0/32 主機拒絕那個ip段訪問=0.0.0.0/32
auth users = backup1 指定使用者=backup1裏面記載的用戶
secrets file = /etc/rsync.password 祕密文件放到=/etc/rsync.password
chmod 777 /back
echo "backup1:123456" > /etc/rsync.password 配置帳號密碼shell
chmod 600 /etc/rsync.password
echo "/usr/bin/rsync --daemon">>/etc/rc.local 設置開機啓動
rsync --daemon 啓動rsync
ps -ef |grep rsync 檢測rsync是否啓動
root 15035 1 0 10:28 ? 00:00:00 rsync --daemon
root 15041 14973 0 10:30 pts/0 00:00:00 grep rsync
192.168.12.25 (rsync+inotify)操做
rpm -qa |grep rsync
echo "123456">/etc/rsync.password
chmod 600 /etc/rsync.password
rsync -vzrtopg --progress /etc backup1@192.168.12.22::back --password-file=/etc/rsync.password 將/etc推送到服務端/back目錄
192.168.12.22 操做
ll /back/
總用量 4
drwxr-xr-x 86 root root 4096 11月 15 10:52 etc
192.168.12.25 操做
ll /proc/sys/fs/inotify/ 查看是否支持inotify
總用量 0
-rw-r--r-- 1 root root 0 11月 15 05:45 max_queued_events
-rw-r--r-- 1 root root 0 11月 15 05:45 max_user_instances
-rw-r--r-- 1 root root 0 11月 15 05:45 max_user_watches
拓展:
一、/proc/sys/fs/inotify/max_queued_evnets
表示調用inotify_init時分配給inotify instance中可排隊的event的數目的最大值,超出這個值的事件被丟棄,但會觸發IN_Q_OVERFLOW事件。
二、/proc/sys/fs/inotify/max_user_instances
表示每個real user ID可建立的inotify instatnces的數量上限。
三、/proc/sys/fs/inotify/max_user_watches
表示每一個inotify instatnces可監控的最大目錄數量。若是監控的文件數目巨大,須要根據狀況,適當增長此值的大小。
例如: echo 30000000 > /proc/sys/fs/inotify/max_user_watches
tar zxvf inotify-tools-3.13.tar.gz
cd inotify-tools-3.13
./configure --prefix=/usr/local/inotify
make && make install
cd /usr/local/inotify/
inotify命令經常使用參數詳解:
inotify參數
-m 是保持一直監聽
-r 是遞歸查看目錄
-q 是打印出事件
-e create,move,delete,modify,attrib 是指 「監聽 建立 移動 刪除 寫入 權限」 事件
rsync參數
============================================
-v, --verbose 詳細模式輸出
-q, --quiet 精簡輸出模式
-c, --checksum 打開校驗開關,強制對文件傳輸進行校驗
-a, --archive 歸檔模式,表示以遞歸方式傳輸文件,並保持全部文件屬性,等於-rlptgoD
-r, --recursive 對子目錄以遞歸模式處理
-R, --relative 使用相對路徑信息
-b, --backup 建立備份,也就是對於目的已經存在有一樣的文件名時,將老的文件從新命名爲~filename。可使用--suffix選項來指定不一樣的備份文件前綴。
--backup-dir 將備份文件(如~filename)存放在在目錄下。
-suffix=SUFFIX 定義備份文件前綴
-u, --update 僅僅進行更新,也就是跳過全部已經存在於DST,而且文件時間晚於要備份的文件。(不覆蓋更新的文件)
-l, --links 保留軟鏈結
-L, --copy-links 想對待常規文件同樣處理軟鏈結
--copy-unsafe-links 僅僅拷貝指向SRC路徑目錄樹之外的鏈結
--safe-links 忽略指向SRC路徑目錄樹之外的鏈結
-H, --hard-links 保留硬鏈結
-p, --perms 保持文件權限
-o, --owner 保持文件屬主信息
-g, --group 保持文件屬組信息
-D, --devices 保持設備文件信息
-t, --times 保持文件時間信息
-S, --sparse 對稀疏文件進行特殊處理以節省DST的空間
-n, --dry-run現實哪些文件將被傳輸
-W, --whole-file 拷貝文件,不進行增量檢測
-x, --one-file-system 不要跨越文件系統邊界
-B, --block-size=SIZE 檢驗算法使用的塊尺寸,默認是700字節
-e, --rsh=COMMAND 指定使用rsh、ssh方式進行數據同步
--rsync-path=PATH 指定遠程服務器上的rsync命令所在路徑信息
-C, --cvs-exclude 使用和CVS同樣的方法自動忽略文件,用來排除那些不但願傳輸的文件
--existing 僅僅更新那些已經存在於DST的文件,而不備份那些新建立的文件
--delete 刪除那些DST中SRC沒有的文件
--delete-excluded 一樣刪除接收端那些被該選項指定排除的文件
--delete-after 傳輸結束之後再刪除
--ignore-errors 及時出現IO錯誤也進行刪除
--max-delete=NUM 最多刪除NUM個文件
--partial 保留那些因故沒有徹底傳輸的文件,以是加快隨後的再次傳輸
--force 強制刪除目錄,即便不爲空
--numeric-ids 不將數字的用戶和組ID匹配爲用戶名和組名
--timeout=TIME IP超時時間,單位爲秒
-I, --ignore-times 不跳過那些有一樣的時間和長度的文件
--size-only 當決定是否要備份文件時,僅僅察看文件大小而不考慮文件時間
--modify-window=NUM 決定文件是否時間相同時使用的時間戳窗口,默認爲0
-T --temp-dir=DIR 在DIR中建立臨時文件
--compare-dest=DIR 一樣比較DIR中的文件來決定是否須要備份
-P 等同於 --partial
--progress 顯示備份過程
-z, --compress 對備份的文件在傳輸時進行壓縮處理
--exclude=PATTERN 指定排除不須要傳輸的文件模式
--include=PATTERN 指定不排除而須要傳輸的文件模式
--exclude-from=FILE 排除FILE中指定模式的文件
--include-from=FILE 不排除FILE指定模式匹配的文件
--version 打印版本信息
--address 綁定到特定的地址
--config=FILE 指定其餘的配置文件,不使用默認的rsyncd.conf文件
--port=PORT 指定其餘的rsync服務端口
--blocking-io 對遠程shell使用阻塞IO
-stats 給出某些文件的傳輸狀態
--progress 在傳輸時現實傳輸過程
--log-format=formAT 指定日誌文件格式
--password-file=FILE 從FILE中獲得密碼
--bwlimit=KBPS 限制I/O帶寬,KBytes per second
-h, --help 顯示幫助信息
pwd
/usr/local/inotify
vi inotify.sh
#!/bin/bash
#para
host=192.168.12.22
src=/web 本地監控的目錄
dst=back rsync服務的模塊名
user=backup1 rsync的虛擬用戶
rsync_passfile=/etc/rsync.password 本地調用rsync密碼文件
inotify_home=/usr/local/inotify inotify的安裝目錄
#####
if [ ! -e "$src" ] \
|| [ ! -e "${rsync_passfile}" ] \
|| [ ! -e "${inotify_home}/bin/inotifywait" ] \
|| [ ! -e "/usr/bin/rsync" ];
then
echo "Check File and Folder"
exit 9
fi
/usr/local/inotify/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f%e' -e close_write,delete,create,attrib $src | while read file
do
rsync -avH $src $user@$host::$dst --password-file=$rsync_passfile
done
exit 0
sh /usr/local/inotify/rsync.sh & 後臺運行
vi /etc/rc.d/rc.local (將上面的命令添加到最後一行,保存)bash