rsync+inotify实时同步配置

一、概述

  • Remote Sync,远程同步,它是一个开源的快速备份工具,可以在不同主机之间镜像同步整个目录树
  • 支持增量备份、保持连接和权限,且采用优化的同步算法,传输前执行压缩,因此分床适用于异地备份、镜像服务器等应用
  • 支持本地复制,或者与其他SSH、rsync主机同步

二、实验环境介绍

2台服务器,

一台client客户端:192.168.5.129/24

一台rsync服务器:192.168.5.130/24

三、实验目的

  • client能够远程获取rsync服务器的文件。
  • 并且通过inotify机制监控client获取到文件,编写相关shell脚本;
  • 让client的文件和rsync中的文件实时同步。

四、rsync常用命令

在这里插入图片描述

五、实验步骤

5.1、rsync服务器配置

yum -y install httpd                ##安装web服务器用于测试
yum -y install rsync            ##安装rsync

  • 修改rsync配置文件
uid = nobody
 gid = nobody
 use chroot = yes                            ####禁锢在源目录
 address = 192.168.5.129                   ####监听地址
 port 873                                       ####监听端口号
 log file = /var/log/rsyncd.log            ####日志文件位置
 pid file = /var/run/rsyncd.pid            ####存放进程ID的文件位置
 hosts allow = 192.168.5.0/24              ####允许访问的客户机地址
[wwwroot]                                           ####共享模块名称
 path = /var/www/html                       ####源目录的实际路径
 comment = Document Root of www.51xit.top
 read only =no                                  #####是否只读
 dont comperss = *.gz *.bz2 *.tgz *.zip *.rar *.z             ####同步时不在压缩的文件类型
 auth users =backuper                               #####授权账户
 secrets file = /etc/rsyncd_users.db                 ####存放账户信息的数据文件

  • 创建授权的账号和密码
vi /etc/rsyncd_users.db
backuper:pwd123              ###账号backuper密码pwd123
chmod 600 /etc/rsyncd_users.db   ###修改权限
  • 在httpd站点中写入相关内容用于共享给client,更改站点权限
echo “1111> /var/www/html/111.html
echo “2222> /var/www/html/222.html
chmod 777 /var/www/html
  • 关闭防火墙,启动rsync服务
systemctl stop firewalld
rsync --daemon                   ###启动服务,如果要停止这个服务kill $(cat /var/run/rsyncd.pid)
netstat -anpt |grep rsync                   ##检查873端口是否开启
tcp        0      0 192.168.5.129:873       0.0.0.0:*               LISTEN      90024/rsync 

5.2、客户端client配置

  • 创建abc文件夹用于接收rsync中的文件,
yum -y install rsync  
mkdir /opt/abc  
systemctl stop firewalld         
  • 更改abc文件夹权限
useradd -M -s /sbin/nologin backuper   ###创建程序性用户,此用户要和rsync配置中的用户一致

cd /opt/abc

chmod 777 /opt/abc/

chown backuper:backuper abc

  • 添加免交互
vi /etc/server.pass
pwd123
chmod 600 /etc/server.pass             ##修改文件权限
  • 下载监控软件inotify-tools并配置
yum install gcc gcc-c++ -y             ##安装环境依赖

tar xzvf inotify-tools-3.14.tar.gz -C /opt    ###解压

cd inotify-tools-3.14/

./configure                   ###编译并安装

make && make install
  • 修改inotify参数
vi /etc/sysctl.conf
fs.inotify.max_queued_events = 32768             ###监控队列大小
fs.inotify.max_user_instances = 1024             ###最多监控实例数
fs.inotify.max_user_watches = 1048576          ###每个实例最多监控文件数

sysctl -p  ####重新加载
  • 编写shell脚本执行同步操作
vim /opt/inotify.sh
#!/bin/bash
INOTIFY_CMD="inotifywait -mrq -e create,delete,move,modify,attrib /opt/abc/"
RSYNC_CMD="rsync -azH --delete --password-file=/etc/server.pass /opt/abc/ [email protected]::wwwroot"
 
$INOTIFY_CMD | while read DIRECTORY EVENT FILE
do
    if [ $(pgrep rsync | wc -l) -le 0 ] ; then
        $RSYNC_CMD
#       echo "${FILE} was rsynced" >>/opt/inotify_rsync.log

    fi
done
  • 修改脚本权限
chmod +x /opt/inotify.sh 

六、验证

  • 在client上执行远程同步,获取rsync共享模块[wwwroot]中的文件到abc文件夹中
rsync -az --delete --password-file=/etc/server.pass backuper@192.168.5.129::wwwroot /opt/abc

在这里插入图片描述

  • 开启客户端inotify监控,并执行 /opt/inotify.sh 脚本
inotifywait -mrq -e modify,create,move,delete  /opt/abc   ##开启对abc文件夹的监控

cd /opt                                 ##执行shell脚本
./inotify.sh                 

  • 重新开一个client终端,在/opt/abc中写入相关文件
vi /opt/abc/333.html
333
  • 能够发现inotify-tools是实时监控我们对/opt/abc文件夹的操作

在这里插入图片描述

  • 进入rsync服务器中,发现通过shell脚本已经将client中abc下的文件同步到rsync服务器中

在这里插入图片描述

发布了60 篇原创文章 · 获赞 66 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/weixin_42953006/article/details/105061365
今日推荐