zoukankan      html  css  js  c++  java
  • CentOS7 Rsync服务搭建-Rsync+Inotify架构实现实时同步

    一.rsync 概念

    1.rsync
    rsync是类unix/linux系统下的数据镜像备份工具。使用快速增量备份工具Remote Sync可以远程同步,支持本地复制,或者与其他SSH、rsync主机同步。rsync是通过超级守护进程xinetd进行触发同步和管理的。CentOS6.4默认已经安装rsync,但未安装xinetd

    2.inotify
    Inotify 是一种强大的、细粒度的、异步的文件系统事件监控机制,linux内核从2.6.13起,加入了Inotify支持,通过Inotify可以监控文件系统中添加、修改、移动等各种细微事件,利用这个内核接口,第三方软件就可以监控文件系统下文件的各种变化情况,而inotify-tools就是这样的一个第三方软件。
    3、rsync+inotify 之推荐理由
    1)服务器性能:rsync+crontab会定时去检查是否有文件更新,即便没有更新也会去检查,这势必会造成服务器性能下降;而rsync+inotify组合是触发式更新,只有在数据文件有变化时,才会去更新,因此相对前者而言,是提高了服务器性能
    2)数据实时性:rsync+crontab是周期性任务计划,不能保证数据的实时性;rsync+inotify组合是触发式更新,只要有数据变化,就立刻同步更新
    3)当同步的目录数据量巨大时,建议使用 Rsync+sersync 架构,具体配置参考:http://www.osyunwei.com/archives/7447.html

    二.rsync 安装

    yum install rsync -y

    三.rsync 的选项说明。

    -a,--archive(存档) 归模式,表示以递归的方式传输文件,并且保持文件属性,等同于加了参数-rlptgoD

    -r,–recursive 对子目录以递归模式处理

    -l,--links 表示拷贝链接文件

    -p , --perms 表示保持文件原有权限

    -t , --times 表示保持文件原有时间

    -g , --group 表示保持文件原有属用户组

    -o , --owner 表示保持文件原有属主

    -D , --devices 表示块设备文件信息

    -z , --compress 表示压缩传输

    -H 表示硬连接文件

    -A 保留ACL属性信息

    -P 显示传输进度

    -u, --update 仅仅进行更新,也就是跳过所有已经存在于目标位置,并且文件时间晚于要备份的文件。(不覆盖更新的文件)

    --port=PORT 指定其他的rsync服务端口  873

    --delete 删除那些目标位置有而原始位置没有的文件

    --password-file=FILE 从FILE中得到密码
    --bwlimit=KBPS 限制I/O带宽,Kbytes /second

    --filter “- 文件名”需要过滤的文件

    --exclude= :需要过滤的文件

    -v 显示同步过程的详细信息

    四.测试环境

    1.环境

    数据服务器: 192.168.1.195

    目标服务器:192.168.1.196

    2.免秘钥登录服务器

    3.同步命令:

    [root@master home]#rsync -avz /home/backup root@192.168.1.196:/home

    目标服务:

    五.inotify 部署安装

    1.下载网址

    wget http://github.com/downloads/rvoicilas/inotify-tools/inotify-tools-3.14.tar.gz

    2.安装

    #tar -zxvf inotify-tools-3.14.tar.gz

    #cd inotify-tools-3.14

    #./configure --prefix=/usr/local/inotify-tools-3.14

    #make && make install

    #ln -s /usr/local/inotify-tools-3.14/ /usr/local/inotify-tools ##创建软链接

    #cd /usr/local/inotify-tools

    ##提示编译成功后会生成4个目录,分别是:

    #ll

    total 16

    drwxr-xr-x. 2 root root 4096 Jan 31 01:55 bin ##inotify执行命令(二进制)

    drwxr-xr-x. 3 root root 4096 Jan 31 01:55 include ##inotify程序所需用的头文件

    drwxr-xr-x. 2 root root 4096 Jan 31 01:55 lib ##动态链接的库文件

    drwxr-xr-x. 4 root root 4096 Jan 31 01:55 share ##帮助文档

    六.工具集合介绍:

    一共安装了2个工具(命令),即inotifywait和inotifywatch

    inotifywait:在被监控的文件或目录上等待特定文件系统事件(open、close、delete等)发生,执行后处于阻塞状态,适合在shell脚本中使用。

    inotifywatch:收集被监视的文件系统使用度统计数据,指定文件系统事件发生的次数统计。

    七.inotify命令常用参数详解:

    # ./bin/inotifywait --help

    inotifywait 3.14

    Wait for a particular event on a file or set of files.

    Usage: inotifywait [ options ] file1 [ file2 ] [ file3 ] [ ... ]

    Options:

    -r|--recursive Watch directories recursively. ##递归查询目录

    -q|--quiet Print less (only print events) ##打印很少的信息,仅仅打印监控相关的信息

    -m|--monitor Keep listening for events forever. Without

    this option, inotifywait will exit after one

    event is received. ##始终保持事件监听状态

    --excludei <pattern>

    Like --exclude but case insensitive. ##排除文件或目录时,不区分大小写

    --timefmt <fmt> strftime-compatible format string for use with

    %T in --format string. ##指定时间的输出格式

    八、测试监控事件(开两个窗口,一个窗口执行命令,另一窗口对监控目录做增、删、改操作)

    1.测试脚本

     1 #!/bin/bash
     2 
     3 #实行当前命令后,界面处于阻塞状态,只有在另外一个客户端测试时,才会显示监控状态
     4 
     5 /usr/local/inotify-tools/bin/inotifywait -mrq -e modify,create,move,delete,attrib /home/backup |while read events    
     6 
     7 do
     8 rsync -a --delete /home/backup 192.168.1.196::test
     9 echo "`date +'%F %T'` 出现事件 $events" >>/tmp/rsync.log 2>&1
    10 done

    2.目标主机添加test用户

    [root@node01 backup]# vi /etc/rsyncd.conf  (配置文件最下面添加)

    [test]
    path = /home/
    read only = false
    uid = root
    gid = root

    3.执行命令

    [root@master inotify-tools]# nohup ./rsync_back.sh &

    4.开启另一个窗口执行删除, 修改,创建等命令

    5.查看nohup的日志

     6.目标服务器,自动生成文件和修改的内容。

  • 相关阅读:
    安卓打包名称
    安卓判断麦克风权限
    Redis基础了解
    Redis的安装
    SVN的日常使用和安装
    Maven基础2
    Maven基础1
    ResultSet的Type
    Hibernate高级查询QBC条件设置——Restrictions用法 引自:http://www.cnblogs.com/evon168/archive/2010/10/29/1863059.html
    Spring配置事务 http://www.cnblogs.com/leiOOlei/p/3725911.html
  • 原文地址:https://www.cnblogs.com/zoulixiang/p/9486742.html
Copyright © 2011-2022 走看看