一、什么是rsync
rsync (remote sync)是一款非常好的数据同步工具,能够通过对比同步双方的数据变动,实现增量同步,还可以通过LAN/WAN实现远程多台主机间文件的同步,还能结合crond任务计划来执行自动备份,又可以结合ssh实现远程数据备份的安全,种种特性使他看起来相当优秀。但如果需备份数据十分庞大时,它的不足之处就显现出来了,比如每次执行同步操作时,rsync都会扫描全部数据进而计算出增量部分,而后再同步增量数据,这将会十分耗时,使其变得低效;并且受限于crond计划任务最小时间间隔为一分钟,会导致同步源端和目的段数据不一致,这在高可用环境中是不被允许的。这个时候我们就可以构建rsync+Inotify架构来解决此应用瓶颈。
二、inotify简介
inotify是内核的一个功能,众所周知内核的功能我们必须要配合工具才能使用,通常情况下用户要使用内核的功能,都需要用户空间的软件去调用才可以达到使用内核的功能的目的,用户是无法直接操内核的。实现inotify软件有inotify-tools、sersync、lrsyncd。我们这里以inotify-tools这个软件包为例进行实验;inotify-tools包主要有两个文件,一个是inotifywait: 在被监控的文件或目录上等待特定文件系统事件(open close delete等)发生,常用于实时同步的目录监控;一个是inotifywatch:收集被监控的文件系统使用的统计数据,指文件系统事件发生的次数统计。通常情况下我们使用iontifywait就可以了。接下来我们来安装inotify-tools
三、环境两台服务器
源服务器:192.168.15.2
目标服务器:192.168.15.4
四、需求
把源服务器上附件实时同步备份至目标服务器
五、目标服务器环境配置
1.安装rsync软件
第一种安装方式:
yum -y install rsync
第二种安装方式:
cd /home/software
wget https://download.samba.org/pub/rsync/src/rsync-3.1.2.tar.gz
tar -zxvf rsync-3.1.2.tar.gz
cd rsync-3.1.2
./configure --prefix=/usr/local/rsync
make
make install
2.rsync配置rsyncd.conf文件
vim /etc/rsyncd.conf //增加以下内容
log file = /var/log/rsyncd.log //日志文件位置,启动rsync后自动产生,无需提前创建
pidfile = /var/run/rsyncd.pid //pid文件存放位置
lock file = /var/run/rsync.lock //支持max connections参数的锁文件
secrets file = /etc/rsync.password//用户认证配置文件,里面存放用户名称和密码,必须手动创建这个文件
[backup] //自定义同步名称
path = /data/backup/ //rsync服务端存放路径,客户端的数据将同步到此目录
comment = sync etc from client
uid = root //设置rsync运行权限为root
gid = root //设置rsync运行权限为root
port = 873 //默认端口为873
ignore errors //表示出现错误忽视错误
use chroot = no //默认为true ,修改为no,增加对目录软链接的备份
read only = no //设置rsync服务端为读写权限
list = no //不显示rsync服务端资源列表
max connections = 200 //最大连接数
timeout = 600 //设置超时时间
auth users = admin //执行数据同步的用户名,可以设置多个,用英文逗号隔开
hosts allow = 192.168.15.2 //允许进行数据同步的IP地址,可以设置多个,用英文逗号隔开
hosts deny = 192.168.24.188 禁止进行数据同步的IP地址,可以设置多个,用英文逗号隔开
3.创建备份目录
mkdir /data/backup
4.创建同步使用账号密码
echo 'root:518' > etc/rsync.password
cat etc/rsync.password
root:518
5.设置文件权限
chmod 600 /etc/rsync*
ll /etc/rsync*
-rw-------. 1 root root 880 Aug 13 14:54 /etc/rsyncd.conf
-rw-------. 1 root root 10 Aug 13 14:55 /etc/rsync.password
6.启动rsync服务并设置开机自启动
systemctl start rsyncd
systemctl enable rsyncd
Created symlink from /etc/systemd/system/multi-user.target.wants/rsyncd.service to /usr/lib/systemd/system/rsyncd.service.
以上操作完毕之后,目标服务器已经配置完毕
六、源服务器环境配置
1.关闭防火墙与SELINUX
systemctl stop firewalld
systemctl disable firewalld
sed -ri 's/^(SELINUX=).*/\1disabled/g' /etc/sysconfig/selinux
setenforce 0
2.安装rsync服务端软件,只需要安装,不要启动,不需要配置(同目标服务器安装方式)
3.创建账户
echo '518' > /etc/rsync.pass
cat /etc/rsync.pass
518
4.设置文件权限
chmod 600 /etc/rsync.pass
ll /etc/rsync.pass
-rw-------. 1 root root 0 Aug 13 15:46 /etc/rsync.pass
5.测试
mkdir data/attachment
rsync -avH --port 873 --progress --delete /root/etc/ root@192.168.15.4::backup --password-file=/etc/rsync.pass
sending incremental file list
./
test/
sent 69 bytes received 22 bytes 182.00 bytes/sec
total size is 0 speedup is 0.00
出现以上情况表示两台服务器人rsync环境已经搭建成功
七、源服务器安装inotify-tools工具,实时触发rsync同步
1.检查服务器内核是否支持inotify
//检查服务器内核是否支持inotify
ll /proc/sys/fs/inotify/
total 0
-rw-r--r--. 1 root root 0 Aug 13 16:13 max_queued_events
-rw-r--r--. 1 root root 0 Aug 13 16:13 max_user_instances
-rw-r--r--. 1 root root 0 Aug 13 16:13 max_user_watches
//如果有这三个max开头的文件则表示服务器内核支持inotify
//安装inotify-tools
yum -y install make gcc gcc-c++ inotify-tools
2.写实时同步脚本
#!/bin/bash
host=192.168.15.4 //目标服务器的ip(备份服务器)
src=/data/attachment //在源服务器上所要监控的备份目标
des=backup //自定义的模块名,需要与目标服务器上的定义名称同步
password=/etc/rsync.password //执行数据同步的密码文件
user=root //执行数据同步的名
inotifywait -mrq --timefmt '%Y%m%d %H:%M' --format '%T %w%f%e' -e modify,delete,create,attrib $src | while read files
do
rsync -avzP --delete --timeout=100 --password-file=${password} $src $user@$host::$des
echo "${files} was rsynced" >>/data/log/rsync/rsync.log 2>&1
done
3.检查脚本是否存在问题
bash -x /sh/rsync.sh
4.启动脚本
nohup bash /jysoft/sh/rsync.sh &
ps -ef|grep inotify
5.测试,再源服务器上新建目录之后,查看目标服务器是否存在,如果存在表示成功
6.设置开机自启
chmod +x /etc/rc.d/rc.local
ll /etc/rc.d/rc.local
-rwxr-xr-x. 1 root root 473 Apr 11 15:36 /etc/rc.d/rc.local
echo 'nohup /bin/bash /jysoft/sh/rsync.sh' >> /etc/rc.d/rc.local
tail /etc/rc.d/rc.local
# to run scripts during boot instead of using this file.
#
# In contrast to previous versions due to parallel execution during boot
# this script will NOT be run after all other services.
#
# Please note that you must run 'chmod +x /etc/rc.d/rc.local' to ensure
# that this script will be executed during boot.
touch /var/lock/subsys/local
nohup /bin/bash /jysoft/sh/rsync.sh