天天看点

rsync+inotify实现实时同步更新

rsync

工作模式:

1、单个主机,cp

2、ssh通道,scp

3、守护进程

rsync -avzP /1 /tmp

rsync --delete -r /2/ /1(删除1下的2目录)

rsync /etc/hosts -e 'ssh -p 52113' root@ip:/

-z:压缩传输

-a:子目录递归

-o:保持文件属主

-p:保持文件权限

-g:保持文件属组

-l:保持链接文件

--exclude:指定不需要传输的文件或文件夹

--exclude-from:

守护进程模式:

vim /etc/rsyncd.conf

添加:

log file=/var/log/rsync.log

pid file=/var/run/rsyncd.pid

use chroot = no

timeout = 300

[test]

path=/tmp/syk/

use chroot=true

max connections=4

read only=no

list=true

uid=root

gid=root

auth users=syk

secrets file=/etc/rsyncd.passwd

创建用户:

groupadd rsync

useradd  -g rsync rsync -s /sbin/nologin

chown -R rsync.rsync /tmp/syk/

rsync --daemon(启动)

cat /etc/rsyncd.passwd 

syk:syk123

chmod 600 /etc/rsyncd.passwd

客户端:

yum -y install rsync

echo "syk123" > /etc/rsyncd.passwd

测试:

rsync -avz syk@server_ip::test /tmp

rsync -avz syk@server_ip::test /tmp --password-file=/etc/rsyncd.passwd

rsync -avz rsync://syk@server_ip/test /tmp --password-file=/etc/rsyncd.passwd

无差异同步:

--delete

inotify

inotifywait:

-r:递归

-q:打印很好的信息

-exclude:指定不需要监控的文件或文件夹

-e:指定需要监控的事件

access:目录或文件被访问时

nodify:被修改

attrib:属性被修改时

close:文件被封闭

open:被打开

moved_to:被移动其他目录

move:被移动到当前或其他目录

create:被创建

delete:被删除

unmount:被卸载

    人工测试监控事件:

./bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f' -e create /backup

./bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f' -e create,delete /backup

./bin/inotifywait -mrq  --format '%w%f' -e create,delete /backup

编写监控脚本:

#/bin/bash

/usr/local/inotify/bin/inotifywait -mrq --format '%w%f' -e create,delete /tmp/syk/ \

|while read line

do

rsync --delete -az  /tmp/syk/ [email protected]::test --password-file=/etc/rsyncd.passwd >/dev/null 2>&1

done

exit 0

本文转自 sykmiao 51CTO博客,原文链接:http://blog.51cto.com/syklinux/1851902,如需转载请自行联系原作者