说明:该功能服务端安装sersync2,客户端安装rsync,原理就是服务端主动推送设定目录下的所有更新的文件到各个客户端rsync接收。

rsync大家都知道,是Linux自带的数据同步工具,而sersync2是google大神的开源项目http://code.google.com/p/sersync/

下面给出具体的实现步骤,实现的详细原理大家可以去上面的开源网址,上面说的很详细

  1. 客户端配置,首先系统安装rsync工具,

    [root@yo57 ~]# vi /etc/rsyncd.conf
    
    uid=www
    gid=www
    max connections=36000
    use chroot=no
    log file=/var/log/rsyncd.log
    pid file=/var/run/rsyncd.pid
    lock file=/var/run/rsyncd.lock [yowebtongbu]
    path=/Data/code/adserver
    comment = yo web files
    ignore errors = yes
    read only = no
    hosts allow = 192.168.0.0/24
    hosts deny = *
    [root@yo57 ~]# /usr/bin/rsync --daemon --config=/etc/rsyncd.conf
    [root@yo57 ~]# ps -ef|grep rsyn
    root 1070 29923 0 17:04 pts/4 00:00:00 grep rsyn
    root 32069 1 0 16:54 ? 00:00:00 /usr/bin/rsync --daemon --config=/etc/rsyncd.conf
  2. 写入开机启动项
    [root@yo57 ~]# vi /etc/rc.local
    
    #!/bin/sh
    #
    # This script will be executed *after* all the other init scripts.
    # You can put your own initialization stuff in here if you don't
    # want to do the full Sys V style init stuff. touch /var/lock/subsys/local ulimit -SHn 51200
    /usr/local/nagios/bin/nrpe -c /usr/local/nagios/etc/nrpe.cfg -d
    /usr/local/nginx/sbin/nginx
    /etc/init.d/php_fpm start
    /usr/bin/rsync --daemon --config=/etc/rsyncd.conf
  3. 服务器端
    [root@10 
    local
    ]
    # tar -zxvf sersync2.5.4_64bit_binary_stable_final.tar.gz
    [root@10 
    local
    ]
    # cd sersync2.5.4_64
    [root@10 sersync2.5.4_64]
    # ls
    confxml.xml  sersync2
    [root@10 sersync2.5.4_64]
    # vi confxml.xml

    修改这一段即可

    <localpath 
    watch
    =
    "/Data/code/adserver"
    >
          
    <remote ip=
    "192.168.0.27" 
    name=
    "yowebtongbu"
    />
          
    <!--<remote ip=
    "192.168.8.39" 
    name=
    "tongbu"
    />-->
          
    <!--<remote ip=
    "192.168.8.40" 
    name=
    "tongbu"
    />-->
      
    <
    /localpath
    >

    进行一次完整同步
    [root@10 sersync2.5.4_64]# ./sersync2 -r
    写入脚本并放入开机启动项

    [root@10 sersync2.5.4_64]
    # cat /usr/local/sbin/sersync.sh    
    #!/bin/bash
    PATH=
    /bin
    :
    /sbin
    :
    /usr/bin
    :
    /usr/sbin
    :
    /usr/local/bin
    :
    /usr/local/sbin
    :~
    /bin
    export 
    PATH
       
    SDATH=
    "/usr/local/sersync2.5.4_64"
    SSTART=
    "./sersync2 -r -d"
    SPID=`
    ps 
    -ef|
    grep 
    'sersync2'
    |
    grep 
    -
    v 
    'grep'
    |
    awk 
    '{print $2}'
    `
       
    function_start()
    {
        
    echo 
    -en 
    "\033[32;49;1mStarting sersync2......\n"
        
    echo 
    -en 
    "\033[39;49;0m"
        
    if 
    [ -t ${SPID} ]; 
    then
            
    cd 
    ${SDATH}
            
    ${SSTART} > 
    /dev/null 
    2>&1
            
    printf 
    "Serync2 is the successful start!\n"
        
    else
        
    printf 
    "Sersync2 is runing!\n"
        
    exit 
    1
        
    fi
    }
       
    function_stop()
    {
        
    echo 
    -en 
    "\033[32;49;1mStoping sersync2......\n"
        
    echo 
    -en 
    "\033[39;49;0m"
        
    if  
    [ -t ${SPID} ]; 
    then
            
    printf  
    "Sersync2 program is not runing!\n"
        
    else
            
    kill 
    ${SPID}
            
    printf 
    "Sersync2 program is stoped\n"
        
    fi
    }
       
    function_restart()
    {
        
    echo 
    -en 
    "\033[32;49;1mRestart sersync2......\n"
        
    echo 
    -en 
    "\033[39;49;0m"
        
    if  
    [ -t ${SPID} ]; 
    then
            
    cd 
    ${SDATH}
            
    ${SSTART} > 
    /dev/null 
    2>&1
        
    else
            
    kill 
    ${SPID}
            
    sleep 
    1
            
    cd 
    ${SDATH}
            
    ${SSTART} > 
    /dev/null 
    2>&1
        
    fi
        
    printf 
    "Sersync2 is the successful restart!\n"
    }
       
    function_kill()
    {
        
    killall sersync2
    }
       
    function_status()
    {
        
    if 

    ps 
    -ef|
    grep 
    'sersync2'
    |
    grep 
    -
    v 
    'grep' 

    /dev/null 
    2>&1
        
    then
            
    printf 
    "Sersync2 is down!!!\n"
        
    else
            
    printf 
    "Sersync2 is running now!\n"
        
    fi
    }
       
    if 

    "$1" 

    "start" 
    ]; 
    then
        
    function_start
    elif 

    "$1" 

    "stop" 
    ]; 
    then
        
    function_stop
    elif 

    "$1" 

    "restart" 
    ]; 
    then
        
    function_restart
    elif 

    "$1" 

    "kill" 
    ]; 
    then
        
    function_kill
    elif 

    "$1" 

    "status" 
    ]; 
    then
        
    function_status
    else
        
    echo 
    -en 
    "\033[32;49;1m Usage: sersync2 {start|stop|restart|kill|status}\n"
        
    echo 
    -en 
    "\033[39;49;0m"
    fi


    [root@10 sersync2.5.4_64]
    # vi /etc/rc.local
        
    #!/bin/sh
    #
    # This script will be executed *after* all the other init scripts.
    # You can put your own initialization stuff in here if you don't
    # want to do the full Sys V style init stuff.
        
    touch 
    /var/lock/subsys/local
    #/etc/init.d/lemp start
    /usr/local/nginx/sbin/nginx
    /etc/init
    .d
    /php_fpm 
    start
    /usr/local/zabbix/sbin/zabbix_agentd
    /usr/local/sbin/sersync
    .sh start

整个实现就这么简单,以后主服务器上面/Data/code/adserver目录下有新建、删除、修改文件或文件夹(包括下层递归)的的数据会自动推送到下面的各个服务端对应目录下,如果临时不需要该功能,kill掉服务端即可,操作完以后在手动开启服务端(此时客户端不用动)

Linux文件实时同步,可实现一对多的更多相关文章

  1. linux文件实时同步

    参考博客:https://www.cnblogs.com/MacoLee/p/5633650.html 一.文件同步很简单 服务端:被动的接收传输过来的数据 客户端:主动提供数据给服务端 安装思路:服 ...

  2. linux下两台服务器文件实时同步方案设计和实现

    inux下两台服务器文件实时同步方案设计和实现 假设有如下需求: 假设两个服务器: 192.168.0.1 源服务器  有目录 /opt/test/ 192.168.0.2 目标服务器  有目录 /o ...

  3. Linux服务器间文件实时同步的实现

    使用场景 现有服务器A和服务器B,如果服务器A的指定目录(例如 /home/paul/rsync/ )中的内容发生变更(增删改和属性变更),实时将这些变更同步到服务器B的目标目录中(例如 /home/ ...

  4. (转)Linux下通过rsync与inotify(异步文件系统事件监控机制)实现文件实时同步

    Linux下通过rsync与inotify(异步文件系统事件监控机制)实现文件实时同步原文:http://www.summerspacestation.com/linux%E4%B8%8B%E9%80 ...

  5. rsync+inotify 实现服务器之间目录文件实时同步(转)

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

  6. rsync+inotify-tools文件实时同步

    rsync+inotify-tools文件实时同步案例 全量备份 Linux下Rsync+sersync实现数据实时同步完成. 增量备份 纯粹的使用rsync做单向同步时,rsync的守护进程是运行在 ...

  7. inotify用法简介及结合rsync实现主机间的文件实时同步

    一.inotify简介 inotify是Linux内核2.6.13 (June 18, 2005)版本新增的一个子系统(API),它提供了一种监控文件系统(基于inode的)事件的机制,可以监控文件系 ...

  8. eclipse 远程文件实时同步,eclipse远程部署插件

    [转自] http://zhwj184.iteye.com/blog/1842730 eclipse 远程文件实时同步,eclipse远程部署插件 github地址:https://github.co ...

  9. Centos 6.5 rsync+inotify 两台服务器文件实时同步

    rsync和inotify是什么我这里就不在介绍了,有专门的文章介绍这两个工具. 1.两台服务器IP地址分别为: 源服务器:192.168.1.2 目标服务器:192.168.1.3 @todo:从源 ...

随机推荐

  1. Servlet中保存的cookie值读取不到

    在设计登录时记住密码功能时,很多时候回使用cookie,在Servlet中保存cookie时,再次访问登录页面,没有读取到保存的cookie值,代码如下: 1 Cookie idCookie = ne ...

  2. CF582A GCD Table

    A. GCD Table time limit per test 2 seconds memory limit per test 256 megabytes input standard input ...

  3. java面试 关键字

    1. final关键字有哪些用法? 修饰类.方法和变量. (1) final变量是只读的,不允许改变其引用,与static共用可声明常量.JVM会对final变量进行优化,比如常量折叠. (2) fi ...

  4. Python 面向对象编程——继承和多态

    <基本定义>     在OOP程序设计中,当我们定义一个class的时候,可以从某个现有的class继承,新的class称为子类(Subclass),而被继承的class称为基类.父类或超 ...

  5. XShell通过中转服务器直接连接目标服务器

    最近由于公司生产环境的变化,使得我们不能使用自己的机器连接到生产环境去,而是要通过跳板机中转才可以连接.于是今天尝试使用 XShell 通过跳板机直接转接到生产环境. 一.使用代理方式 首先填写连接信 ...

  6. luoguP2490 [SDOI2011]黑白棋 博弈论 + 动态规划

    博弈部分是自己想出来的,\(dp\)的部分最后出了点差错QAQ 从简单的情况入手 比如\(k = 2\) 如果有这样的局面:$\circ \bullet $,那么先手必输,因为不论先手怎样移动,对手都 ...

  7. BZOJ.2286.[SDOI2011]消耗战(虚树 树形DP)

    题目链接 BZOJ 洛谷P2495 树形DP,对于每棵子树要么逐个删除其中要删除的边,要么直接断连向父节点的边. 如果当前点需要删除,那么直接断不需要再管子树. 复杂度O(m*n). 对于两个要删除的 ...

  8. 通过IP获取所在城市

    <script type="text/javascript"> var map = new BMap.Map("allmap"); var poin ...

  9. C# 高级编程9 第30章MEF C#可扩展编程之MEF第一章

    MEF(Managed Extensibility Framework)是一个用于创建可扩展的轻型应用程序的库 利用该库轻松地封装代码,避免生成脆弱的硬依赖项. 通过 MEF,不仅可以在应用程序内重用 ...

  10. 电子助视仪 对比增强算法 二十种色彩模式(Electronic Video Magnifier, 20 color mode)

    电子助视仪 是一种将原始彩色图像转换为某种对比度高的图像,例如将原始图像变换为黑底白字,红底白字,白底红字,蓝底黄字,黄字蓝底等等.电子助视仪的主要应用场景为为老人或者特殊弱视人群的阅读.国内国外均有 ...