参考博客:https://www.cnblogs.com/MacoLee/p/5633650.html
一、文件同步很简单
服务端:被动的接收传输过来的数据
客户端:主动提供数据给服务端
安装思路:服务端和客户端都需要安装rsync软件。因为我这里理解的客户端是提供数据给服务端,所以客户端需要实时监测文件的变动,这里的客户端需要安装inotify软件。
安装演示思路:这里按照常规的思路。在服务端安装完rsync软件后,编辑相关的配置文件,并启动rsync。在客户端安装完rsync软件后,不做任何操作,只需要执行相关的同步命令即可。
二、安装rsync软件
1、两种安装方式:(1)、直接使用yum命令安装(本人采用)
yum -y install rsync
(2)、使用编译安装
[[email protected] ~]# cd /usr/local/src/
[[email protected] src]# wget http://rsync.samba.org/ftp/rsync/src/rsync-3.0.9.tar.gz
[[email protected] src]# tar zxvf rsync-3.0.9.tar.gz
[[email protected] src]# cd rsync-3.0.9
[[email protected] rsync-3.0.9]# ./configure --prefix=/usr/local/rsync
[[email protected] rsync-3.0.9]# make
[[email protected] rsync-3.0.9]# make install
2、设置密码认证文件和配置文件
(1)、建立用户和密码认证文件(编译安装时的位置)
(只在服务端做配置文件的修改)
[[email protected] rsync-3.0.9]# echo "web:123" > /usr/local/rsync/rsyncd.passwd
(只在客户端做配置文件的修改)
[[email protected] rsync-3.0.9]# echo "123" > /usr/local/rsync/rsync.passwd
设置权限为只读
[[email protected] rsync-3.0.9]# cd /usr/local/rsync
[[email protected] rsync]# chmod 600 rsyncd.passwd
(2)、建立rsync配置文件(只在服务端做配置文件的修改)
安装方式不同引发的配置文件区别:
<1>、直接使用yum命令安装时
[[email protected] rsync]# vi /etc/rsyncd.conf
# /etc/rsyncd: configuration file for rsync daemon mode
# See rsyncd.conf man page for more options.
uid = root
gid = root
use chroot = no
max connections = 200
timeout = 1000
transfer logging = yes
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsyncd.lock
log file = /var/log/rsyncd.log
log format = %t %a %m %f %b
port = 873
ignore errors
#read only = yes
#address = 192.168.248.136
[web]
path = /home
read only = false
write only = yes
hosts allow = 192.168.248.138 192.168.248.136
hosts deny = *
list = false
auth users = web
secrets file = /usr/local/rsync/rsyncd.passwd
#read only = yes
#exclude = test/ #不同步的目录
<2>、使用编译安装(举例)
[[email protected] rsync]# vi /usr/local/rsync/rsyncd.conf
uid = root
gid = root
use chroot = no
max connections = 4
strict modes = yes
hosts allow = 192.168.1.101 #可以空格,允许多个
port = 873
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
log file = /var/log/rsyncd.log
[test]
path = /home/test
ignore errors
read only = false
list = false
auth users = backup
secrets file = /usr/local/rsync/rsyncd.passwd
PS:注意这里要将read only 修改为 false, 因为是要将文件同步到该模块的,必须可写
(3)、以守护进程方式启动rsync服务器(客户端不需要启动,就是没有修改配置文件的客户端)
<1>、使用yum命令安装时
rsync --daemon
<2>、使用编译安装时
rsync --daemon --config=/usr/local/rsync/rsyncd.conf
(4)、加入开机自启动
echo "/usr/local/rsync/bin/rsync --daemon --config=/usr/local/rsync/rsyncd.conf" >> /etc/rc.local
三、安装inotify软件
在客户端(就是要监测文件变化的那端)安装inotify。
(1)、验证rsync是否安装成功
举例1:客户端上执行,客户端向服务端复制文件
/usr/bin/rsync -vzrtopg --progress --password-file=/etc/web.passwd /home/fan [email protected]::web
举例2:客户端上执行,服务端向客户端复制文件
[[email protected] rsync]# rsync -vzrtopg --delete --progress --password-file=/usr/local/rsync/rsync.passwd [email protected]::test /home/test
(2)、安装inotify
[[email protected] rsync]# cd /usr/local/src/
[[email protected] src]# wget http://cloud.github.com/downloads/rvoicilas/inotify-tools/inotify-tools-3.14.tar.gz
[[email protected] src]# tar zxvf inotify-tools-3.14.tar.gz
[[email protected] src]# cd inotify-tools-3.14
[[email protected] inotify-tools-3.14]# ./configure --prefix=/usr/local/inotify
[[email protected] inotify-tools-3.14]# make
[[email protected] inotify-tools-3.14]# make install
(3)、创建rsync复制脚本
此项功能主要是将客户端的目录/home/fan/里的内容,如果修改了(无论是添加、修改、删除文件)能够通过inotify监控到,并通过rsync实时的同步给服务端的/home里,下面是通过shell脚本实现的。
#!/bin/bash
host=192.168.248.136
src=/home/fan
des=web
user=web
/usr/local/inotify/bin/inotifywait -mrq --timefmt ‘%d/%m/%y %H:%M‘ --format ‘%T %w%f%e‘ -e modify,delete,create,attrib $src | while read files
do
/usr/bin/rsync -vzrtopg --progress --delete --password-file=/etc/web.passwd $src [email protected]$host::$des
echo "${files} was rsynced" >>/data/logs/rsync.log 2>&1
done
其中host是client的ip,src是客户端要实时监控的目录,des是认证的模块名,需要与client一致,user是建立密码文件里的认证用户。
运行脚本
[[email protected] rsync]# sh /tmp/rsync.sh &
把rsync.sh脚本加入到开机启动项里
[[email protected] rsync]# echo "setsid /usr/local/rsync/rsync.sh &" >> /etc/rc.local
原文地址:https://www.cnblogs.com/zzf0305/p/9319962.html