|
1.架构
服务器端:192.168.202.135
客户端:192.168.202.129
2.rsync服务器端安装配置
1
| yum install rsync -y #安装rsync服务
|
为rsync服务提供配置文件:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
| vim /etc/rsyncd.conf #文件默认不存在,添加以下内容
uid = root #启动服务进程的用户
gid = root #启动服务进程的用户组
port = 873 #以守护进程启动rsync服务时监听的端口号
hosts allow = 192.168.202.0/24 #允许哪些客户端能够连接服务
max connections = 0 #指定该服务的最大并发连接数,为0表示不限制
timeout= 300 #指定超时时间
pid file = /var/run/rsyncd.pid #pid文件路径
lock file = /var/run/rsync.lock #锁文件路径
log file = /var/log/rsyncd.log #日志文件路径
[backup] #模块声明
path =/rsync/test #指定当前模块在rsync服务器上的同步路径,该参数是必须指定的
read only = no #是否允许客户端上传文件
list = no #当客户请求列出可以使用的模块列表时,该模块是否应该被列出
auth users = rsync #指定由空格或逗号分隔的用户名列表,只有这些用户才允许连接该模块
secrets file = /etc/rsync.passwd #保存密码和用户名文件,需要自己生成
|
设置密码文件:
1
2
3
4
5
| vim /etc/rsync.passwd #添加以下内容
rsync:123456
chmod 600 /etc/rsync.passwd #修改密码文件权限为600
|
注:当配置文件中参数strict modes为true时,rsync认证口令文件的权限一定是600,否则客户端将不能连接服务器。rsync认证口令文件中每一行指定一个 用户名:口令 对,格式为:username:passwd。
启动rsync服务并设置开机自启动:
1
2
| /usr/bin/rsync --daemon #以守护进程方式启动rsync服务
echo "/usr/bin/rsync --daemon">>/etc/rc.local #添加开机自启动
|
3.rsync客户端安装与配置
安装inotify-tools:
在安装inotify-tools前请先确认你的linux内核是否达到了2.6.13,并且在编译时开启了CONFIG_INOTIFY选项,也可以通过以下命令检测,如果出现以下输出,说明支持:
1
2
| [iyunv@localhost ~]# ls /proc/sys/fs/inotify/
max_queued_events max_user_instances max_user_watches
|
安装:
编写rsync.sh监控脚本:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
| #!/bin/bash
host=192.168.202.135
src=/data/www/
des=backup
user=rsync
/usr/local/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f' \
-e modify,delete,create,attrib \
${src} \
| while read file
do
rsync -vzrtopg --delete --progress ${src} ${user}@${host}::${des} --password-file=/etc/www.pwd &&
echo "${files} was rsynced" >> /tmp/rsync.log 2>&1
echo "---------------------------------------------------------------------------"
done
|
建立认证文件(客户端认证文件只用加入密码即可)并后台运行rsync.sh脚本:
1
2
3
4
| echo 'rsync' >> /etc/www.pwd
chmod 600 /etc/ww.pwd
nohup sh /root/rsync.sh &
echo "nohup sh /root/rsync.sh &" >> /etc/rc.local
|
|
|
|