多机部署之使用rsync+inotify实时双向同步代码

rsync可以实现触发式的文件同步,但是通过crontab守护进程方式进行触发,同步的数据和实际数据会有差异,而inotify可以监控文件系统的各种变化,当文件有任何变动时,就触发rsync同步,这样刚好解决了同步数据的实时性问题。

  1. 安装rsync(两台服务器都要装)

    1
    yum install -y rsync
  2. 创建或者修改 /etc/rsyncd.conf

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    #rsync通用配置文件,配置的注释不要写在配置后面,否则会有问题
    uid = root
    gid = root
    use chroot = 0
    port = 873
    #允许ip访问设置,请根据实际需要进行配置,这里为了方便设为全网段 *,生产环境下为了安全请指定ip或ip段
    # hosts allow = 192.168.0.1/255.255.255.0 198.162.145.1 10.0.1.0/255.255.255.0
    hosts allow = *
    max connections = 0
    timeout = 300
    pid file = /var/run/rsyncd.pid
    lock file = /var/run/rsyncd.lock
    log file = /var/log/rsyncd.log
    log format = %t %a %m %f %b
    transfer logging = yes
    syslog facility = local3
    #方括号中为模块声明,对应命名,这里master_web对应了主web机配置,从服务器可都为[slave_web],方便inotify脚本配置
    [master_web]
    #指定当前模块在rsync服务器上的同步路径,该参数是必须指定的
    path = /home/wwwroot/
    #注释,可以同模块名一样,从服务器可都为slave_web
    comment = master_web
    ignore errors
    #是否允许客户端上传文件
    read only = no
    list = no
    #指定由空格或逗号分隔的用户名列表,只有这些用户才允许连接该模块
    auth users = rsync
    #保存密码和用户名文件,需要自己生成
    secrets file = /etc/rsyncd.passwd
  3. 创建或者修改 /etc/rsyncd.passwd和/root/rsyncd.passwd

    1
    2
    3
    4
    #/etc/rsyncd.passwd中内容格式 用户名:密码 ,多个用户名密码则每添加多行,建议从web机都是一样的用户名和密码
    rsync:123456
    #/root/rsyncd.passwd中内容只需要填写从服务器的密码,例如这里从服务器配的用户名密码都是rsync:123456,这里主服务器则写123456一个就可以了
    123456
  4. 给文件赋权限

    1
    2
    chmod 600 /etc/rsyncd.passwd
    chmod 600 /root/rsyncd.passwd
  5. 以守护进程方式启动rsync服务

    1
    /usr/bin/rsync --daemon --config=/etc/rsyncd.conf
  6. 添加开机自启动

    1
    echo "/usr/bin/rsync --daemon --config=/etc/rsyncd.conf">>/etc/rc.local
  7. 验证代码是否同步

    1
    2
    3
    4
    5
    # 主web服务器推送代码到从web服务器,命令中的
    # rsync@192.168.10.230::slave_web# 192.168.10.230 为从web服务器的ip,
    # slave_web 为从web服务器的 rsyncd.conf 中配置的模块名,
    # rsync 为为从web服务器的中 rsyncd.passwd 中配置的用户名
    rsync -vzrtopg --delete --progress /home/wwwroot/ rsync@192.168.10.230::slave_web --password-file=/root/rsyncd.passwd
  8. 安装inotify(两台服务器都要安装)

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    wget http://github.com/downloads/rvoicilas/inotify-tools/inotify-tools-3.14.tar.gz --no-check-certificate
    tar -zxvf inotify-tools-3.14.tar.gz
    makedir /usr/local/inotify
    cd inotify-tools-3.14.tar.gz
    ./configure --prefix=/usr/local/inotify
    make && make install
    # 查看是否安装成功
    ls -alh /usr/local/inotify/bin/inotify*
    # 建立软连接
    ln -s /usr/local/inotify/bin/inotifywait /usr/bin/inotifywait
    ln -s /usr/local/inotify/bin/inotifywatch /usr/bin/inotifywatch
  9. 配置rsync.sh同步监控脚本

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    vi /root/rsync.sh

    # 内容如下
    #!/bin/bash
    src=/home/wwwroot/
    des=master_web #视情况自己配置,注意与下面的rsync命令结合配置
    user=rsync


    #多个ip就用空格间断,所有IP用一个双引号包起来
    host="192.168.10.230"
    /usr/bin/inotifywait -mrq –exclude=public –exclude=themes –exclude=wap_themes –timefmt '%d/%m/%y %H:%M' –format '%T %w%f' -e modify,delete,create,attrib src | while read file
    do
    for hostip in host
    do
    rsync -vzrtopg –delete –progress –exclude=themes –exclude=wap_themes –exclude=public {src} {user}@{hostip}::{des} –password-file=/root/rsyncd.passwd
    echo "${file} was rsynced" >> /tmp/rsync.log 2>&1
    done
    done
  10. 给rsync.sh脚本赋可执行权限

    1
    chmod +x /root/rsync.sh
  11. 运行rsync.sh同步监控脚本和配置守护进程

    1
    2
    3
    4
    nohup sh /root/rsync.sh &

    #建立守护进程运行rsync.sh脚本
    echo “nohup sh /root/rsync.sh &” >> /etc/rc.local
0%