赞
踩
rsync是可以实现增量备份的工具。配合任务计划,rsync能实现定时或间隔同步,配合inotify或sersync,可以实现触发式的实时同步。
本地文件系统上实现同步:
rsync -auv /opt/rsync/ /opt/local/
本地主机使用远程shell和远程主机通信(scp方式)
rsync -auv /opt/rsync/ root@192.168.1.101:/opt/test
本地主机通过网络套接字连接远程主机上的rsync daemon
rsync -auv /opt/rsync test@192.168.1.101::test
说明:
-n 仅测试传输,而不实际传输。常和"-vvvv"配合使用来查看rsync是如何工作的。
-auv (一般常用此3个参数同步)
-v:显示rsync过程中详细信息。可以使用"-vvvv"获取更详细信息
-a --archive :归档模式,表示递归传输并保持文件属性。等同于"-rtopgDl"。
-u --update :仅在源mtime比目标已存在文件的mtime新时才拷贝。注意,该选项是接收端判断的,不会影响删除行为
–exclude 排除某个目录/文件 rsync -r -v --exclude=“anaconda/*.log” /var/log/anaconda /var/log/audit /tmp
–delete 使用"–delete"选项后,接收端的rsync会先删除目标目录下已经存在,但源端目录不存在的文件。
也就是"多则删之,少则补之"。
注:如果将"–delete"选项和"–exclude"选项一起使用,则被排除的文件不会被删除
yum install -y httpd
yum install -y rsync
vim /etc/rsyncd.conf
uid = nobody
gid = nobody
use chroot = yes
port 873
max connections = 4
log file = /var/log/rsyncd.log
pid file = /var/run/rsyncd.pid
hosts allow = 192.168.60.0/24
[wwwroot]
path = /var/www/html
comment = www.test.com
read only = yes
dont compress = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2
auth users = backuper
secrets file = /etc/rsyncd_users.db
vim /etc/rsyncd_users.db
backuper:123123
chmod 600 /etc/rsyncd_users.db
rsync --daemon //启动rsync同步服务
netstat -natp | grep rsync //查看端口状态
pkill rsync //结束进程
cd /var/www/html
vim index.html
this is shoudong web
//手动同步方法一
rsync -avz backuper@192.168.60.10::wwwroot /var/www/html
//手动同步方法二
rsync -avz rsync://backuper@192.168.60.10/wwwroot /var/www/html
//免密码登录手动同步方法三
vim /opt/server.pass
chmod 600 /opt/server.pass
rsync -zva --delete --password-file=/opt/server.pass backuper@192.168.60.10::wwwroot /var/www/html
vim /etc/sysctl.conf
fs.inotify.max_queued_events = 16384 //监控事件队列大小
fs.inotify.max_user_instances = 1024 //监控最大实例数
fs.inotify.max_user_watches = 1048576 //每个实例数最多监控文件数,监控数应大于监控的总文件数
sysctl -p
yum install -y gcc gcc-c++
tar zxvf inotify-tools-3.14.tar.gz
cd /opt/inotify-tools-3.14
./configure
make && make install
inotifywait用于持续监控,实时输出结果
inotifywatch用于短期监控,任务完成后在输出结果
-m 持续进行监控
-r 递归监控所有子对象
-q 简化输出信息
-e 指定要监控那些事件类型
inotifywait -mrq -e modify,create,move,delete /var/www/html
另外在开启一个新的终端
//在服务端设置
vim /etc/rsyncd.conf
read only = no
chmod 777 /var/www/html
//在发起端设置
chmod 777 /var/www/html
vim /opt/inotify_rsync.sh
#!/bin/bash
INOTIFY_CMD="inotifywait -mrq -e modify,create,move,delete /var/www/html"
RSYNC_CMD="rsync -avz --delete --password-file=/opt/server.pass backuper@192.168.60.10::wwwroot /var/www/html"
$INOTIFY_CMD | while read DIRECTORY EVENT FILE
do
if [ $(pgrep rsync |wc -l) -le 0 ];then
$RSYNC_CMD
fi
done
sh inotify.sh
在发起端创建比写入内容
[root@promote html]# echo “this is abc web” >> abc.html
查看监听脚本是否正常【下面的error无所谓】
在服务端查看是否同步
【问题一】编译安装inotify-tools工具时出现编译错误
分析:configure: error: no acceptable C compiler found in $PATH错误主要是没有C编译器.
【解决方案】安装C编译器:
[root@localhost ~]# yum -y install gcc gcc-c++
【问题二】执行脚本之后没有效果
分析:出现这个结果说明此脚本信息没有执行,问题出现在脚本中的内容,经过分析脚本的执行在于if条件语句,而最关键的是pgrep rsync | wc -l 。
执行pgrep rsync | wc -l 查看,大于0,所有有rsync进程存在。
【解决方案】关闭发起端的rsync进程
[root@localhost opt]# pkill rsync
[root@localhost opt]# netstat -natp | grep rsync
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。