Rsync + inotify 实现文件实时同步

时间:2022-08-24 23:39:50

Rsync 用来实现触发式的文件同步。
  Inotify-tools是一套组件,Linux内核从2.6.13版本开始提供了inotify通知接口,用来监控文件系统的各种变化情况,如文件存取、删除、移动等。利用这一机制,可以非常方便地实现文件异动告警、增量备份,并针对目录或文件的变化及时作出响应;
所以使用inotify监控文件系统有任何变动时,然后就触发rsync同步,达到了单向实时同步数据的功能。

Rsync

默认安装 或者 源码下载 安装;
 yum install rsync -y  
同步的备机需要启动服务 开启 873 端口;
示例启动 /usr/bin/rsync --daemon
可以添加到 /etc/rc.load 启动项中;

示例:

A: web-server    192.168.2.5
B: web-bak 192.168.2.6

一、web-bak 配置:

在 bak 服务上 安装 Rsync

默认端口是873,默认安装时候没有这个文件 需要手动创建配置文件 rsyncd.conf

对于非匿名访问的 rsync 服务器还要创建认证口令文;

1、创建配置文件:

# vi /etc/rsyncd.conf

[root@web-bak ]# cat /etc/rsyncd.conf 
uid = root
gid = root
use chroot = no
max connections = 100
timeout = 30
strict modes = yes
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
log file = /var/log/rsyncd.log [server1]
path = /backup/
comment = backup file
ignore errors
read only = no
write only = no
hosts allow = 192.16.2.5
# 指定能进行同步的机器。 多个 IP 或者网段 用空格隔开;
# hosts deny = *
list = false
uid = root
gid = root
auth users = bakup
# 验证用户
secrets file = /etc/rsync.pass
# 添加验证密码文件

2、创建 rsync.pass 文件 (需要设置为当前用户下的只读权限)

chmod 600 /etc/rsync.pass

[root@web-bak ]# cat /etc/rsync.pass 
bakup:server1

3、默认启动

默认启动
/usr/bin/rsync --daemon

同步 :

/usr/bin/rsync -vzrtopg --delete --progress --password-file=/etc/user.passwd user@172.16.3.18::server /opt/bak/
#
# user.passwd 密码路径
# rsync dome 服务所在的服务器
# user@172.16.3.18::server 需要同步备份的服务目录,指定 user 账户
# /opt/bak 本地机器路径
# 如果 /opt/bak 在 user@172.16.3.18::server 前,就是本地同步到server服务器上
# 如果 /ope/bak 在后 就是,server 同步备份到本地。

二、web-server 配置:

1、创建  rsync.pass 文件

[root@web-server1 ]# cat /etc/rsync.pass 
server1

2、安装 inotify-tools 

默认yum install 也可以源码进行。

3、创建 检测同步脚本

  ( inotifywait 循环检测文件  Rsync 从而达到实时同步 )

[root@web-server1 ]# cat rsync-inotify.sh 
#!/bin/bash
bak=192.168.2.6
# 备份服务器
src=/bakup/
# 备份目录
dst=server1
# 备份模块
user=bakup
启动账户
/usr/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f%e' -e close_write,modify,delete,create,attrib $src | while read files
do
/usr/bin/rsync -vzrtopg --delete --progress --password-file=/etc/rsync.pass $src $user@$bak::$dst
echo "${files} was rsynced ok ! " >>/tmp/rsync.log 2>&1
     done

4、Rsync 同步参数参考:

-v, --verbose    详细模式输出,详细显示数据传输备份情况
-z, --compress 传输时进行压缩以提高传输效率,--compress-level=NUM可按级别压缩。局域网可以不用压缩
-a, --archive 归档模式,表示以递归方式传输文件,并保持所有文件属性,等价于-rtopgDl
-r, --recursive(属于-a参数) 对子目录以递归模式,即目录下的所有目录都同样传输
-t, --times(属于-a参数) 保持文件时间属性信息
-o, --owner(属于-a参数) 保持文件属主信息
-p, --perms(属于-a参数) 保持文件权限
-g, --group(属于-a参数) 保持文件属组信息
-D, --devices (属于-a参数) 保持设备文件信息
-l, --links(属于-a参数) 保留软链接(小写字母l)
-P, --progress 显示同步的过程及传输时的进度等信息
-e, --rsh=COMMAND 使用的信道协议(remote shell),指定替代rsh的shell程序。例如:ssh
--exclude=PATTERN 指定排除不需要传输的文件信息
--exclude-from=file 文件名所在的目录文件,即可以实现排除多个文件
--bwlimit=RATE 实现数据传输过程限速传输,限制速率单位为kbytes

三、后台启动运行同步脚本

nohup & 启动后台运行

# nohup sh rsync-inotify.sh &

四、 Rsync 是单向同步的;客户端只保持与服务器端的镜像同步;客户端删除并不会影响服务端数据。

unison 可以达到双向镜像同步。

Rsync + inotify 实现文件实时同步的更多相关文章

  1. Rsync+inotify实现文件实时同步#附shell脚本

    强烈推荐先仔细看此文 https://segmentfault.com/a/1190000002427568 实验环境 centos 7.3 vm2:192.168.221.128 同步服务器 vm1 ...

  2. Centos 6.5配置rsync+inotify实现文件实时同步

    1.安装rsync(两台机器执行相同的步骤)yum install gcc yum install rsyncd xinetd -y因为rsync是由xinetd启动的,所以需要修改一个配置vim / ...

  3. rsync+inotify实现文件实时同步

    一.相关组件简介 1.rsync 与传统的cp.tar备份方式相比,rsync具有安全性高.备份迅速.支持增量备份等优点,通过rsync可以解决对实时性要求不高的数据备份需求,例如定期的备份文件服务器 ...

  4. CentOS 6.5 rsync+inotify实现数据实时同步备份

    CentOS 6.5 rsync+inotify实现数据实时同步备份 rsync    remote sync 远程同步,同步是把数据从缓冲区同步到磁盘上去的.数据在内存缓存区完成之后还没有写入到磁盘 ...

  5. sersync+rsync实现服务器文件实时同步

    sersync+rsync实现服务器文件实时同步 一.为什么要用rsync+sersync架构? 1.sersync是基于inotify开发的,类似于inotify-tools的工具 2.sersyn ...

  6. sersync基于rsync+inotify实现数据实时同步

    一.环境描述 需求:服务器A与服务器B为主备服务模式,需要保持文件一致性,现采用sersync基于rsync+inotify实现数据实时同步 主服务器A:192.168.1.23 从服务器B:192. ...

  7. rsync+sersync实现文件实时同步

    前言: 一.为什么要用Rsync+sersync架构? 1.sersync是基于Inotify开发的,类似于Inotify-tools的工具 2.sersync可以记录下被监听目录中发生变化的(包括增 ...

  8. rsync+inotify安装配置 实时同步文件

    安装 #安装inotify 工具 [root@localhost ~]# yum install inotify-tools -y 常用命令 [root@localhost ~]# inotifywa ...

  9. CentOS7之Rsync+Inotify架构实现实时同步文件和文件夹

    简介:rsync是用来同步文件和文件夹的,inotify是用来实现监听变动而自动同步的 OS:Centos7.3 服务器端:172.16.13.157 客 户 端  :172.16.13.156 目  ...

随机推荐

  1. 利用lambda和Collection.forEach

    2.外部VS内部迭代 以前Java集合是不能够表达内部迭代的,而只提供了一种外部迭代的方式,也就是for或者while循环. 1 2 3 4 List persons = asList(new Per ...

  2. JS调用JCEF方法

    坐下写这篇文章的时候,内心还是有一点点小激动的,折腾了一个多星期,踩了一个又一个的坑,终于找到一条可以走通的路,内心的喜悦相信经历过的人都会明白~~~~~今儿个老百姓啊,真呀个真高兴啊,哈哈,好了,废 ...

  3. 把CentOS 7.x网卡名称eno16777736改为eth0

    CentOS 7.x系统中网卡命名规则被重新定义,可能会是"eno167777xx"等,下面我们把网卡名称改为eth0这种. 一.cd  /etc/sysconfig/networ ...

  4. Samba日志分析

    Samba日志分析 随着我们文件共享安全级别的提高,越来越多的情况下需要对日志进行记录并审计.Linux平台下的Samba服务的配置文件是smb.conf,有不少图形化配置工具例如Webmin.smb ...

  5. shell中cut用法

    cut是一个选取命令,就是将一段数据经过分析,取出我们想要的.一般来说,选取信息通常是针对“行”来进行分析的,并不是整篇信息分析的. (1)其语法格式为:cut  [-bn] [file] 或 cut ...

  6. 使用jxl.jar操作Excel

    在工程的build path中添加jxl.jar,网址:http://www.andykhan.com/jexcelapi/ import java.io.BufferedReader; import ...

  7. 完美实现同时分享图片和文字(Intent.ACTION_SEND)

    private void share(String content, Uri uri){ Intent shareIntent = new Intent(Intent.ACTION_SEND); if ...

  8. 利用python进行数据分析之pandas库的应用(一)

    一.pandas的数据结构介绍 Series Series是由一种类似于一维数组的对象,它由一组数据以及一组与之相关的数据索引构成.仅由一组数据可产生最简单的Series. obj=Series([4 ...

  9. A short Glimpse to Spectral Sequences 快速入坑谱序列(英文)

    In this short paper with a few of page (but a lot of language mistake), I want to introduce the theo ...

  10. Linux 系统分级及root权限相关

    单用户模式修改用户密码 救援模式 让我们先来了解一下linux的运行步骤 1. Linux系统引导的顺序掌握Linux系统引导的顺序:BIOSMBRKernelinit其中,BIOS的工作是检查计算机 ...