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
chmod 600 /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/ syk@192.168.137.52::test --password-file=/etc/rsyncd.passwd >/dev/null 2>&1
done
exit 0
本文转自 sykmiao 51CTO博客,原文链接:http://blog.51cto.com/syklinux/1851902,如需转载请自行联系原作者