sersync2.5+rsync实现数据同…

本文详细介绍了如何利用sersync2.5和rsync软件,通过配置rsyncd.conf文件及sersync配置文件,实现源服务器与目标服务器之间的数据同步。包括安装部署、配置细节、同步流程等步骤,确保数据的一致性和实时性。
环境
源服务器IP:192.168.1.51
目标服务器IP:192.168.1.52




目标服务器
#tar -zxvf rsync-3.0.9.tar.gz
#cd rsync-3.0.9
#./configure --prefix=/usr/local/rsync
#make && make install

#cd /usr/local/rsync/
#mkdir etc
#vim /usr/local/rsync/etc/rsyncd.conf


uid=nobody
gid=nobody
use chroot=no
max connections=200
log file=/var/log/rsyncd.log
pid file=/var/run/rsyncd.pid
lock file=/var/run/rsyncd.lock

[http]
uid=root
gid=root
path=/usr/local/nginx/html/sync
comment = wwwroot
read only = no
write only = no
list = yes
ignore errors = yes
hosts allow = 192.168.1.51/24
hosts deny = *

#/usr/local/rsync/bin/rsync --daemon --config=/usr/local/rsync/etc/rsyncd.conf

#iptables -A INPUT -p tcp --dport 873 -j ACCEPT



源服务器
#tar -zxvf sersync2.5.4_64bit_binary_stable_final.tar.gz
#mv GNU-Linux-x86/ /usr/local/sersync2.5
#cd /usr/local/sersync2.5/
# vim /usr/local/sersync2.5/confxml.xml



<?xml version="1.0" encoding="ISO-8859-1"?>
<head version="2.5">
      <host hostip="192.168.1.51" port="8008"></host>
      <debug start="false"/>
      <fileSystem xfs="false"/>
      <filter start="false">
              <exclude expression="(.*).svn"></exclude>
              <exclude expression="(.*).gz"></exclude>
              <exclude expression="^info/*"></exclude>
              <exclude expression="^static/*"></exclude>
      </filter>
      <inotify>
              <delete start="true"/>
              <createFolder start="true"/>
              <createFile start="false"/>
              <closeWrite start="true"/>
              <moveFrom start="true"/>
              <moveTo start="true"/>
              <attrib start="false"/>
              <modify start="false"/>
      </inotify>



      <sersync>
              <localpath watch="/usr/local/nginx/html/sync">
                      <remote ip="192.168.1.52" name="http"/>
                      <!--<remote ip="192.168.8.39" name="tongbu"/>-->
                      <!--<remote ip="192.168.8.40" name="tongbu"/>-->






              <failLog path="/var/log/sersync2.log" timeToExecute="60"/>




配置完成,先做一次整体同步
#/usr/local/sersync2.5/sersync2 -r -o /usr/local/sersync2.5/confxml.xml


守护进程模式启动sersync2
#/usr/local/sersync2.5/sersync2 -d -o /usr/local/sersync2.5/confxml.xml









sersync2配置文件详解

<?xml version="1.0" encoding="ISO-8859-1"?>
<head version="2.5">
      <host hostip="localhost" port="9090"></host>
      <debug start="false"/>
      <fileSystem xfs="false"/>
      <filter start="true">
        <exclude expression="^((?!original.).*)$"></exclude>     
                                      #只备份源里面文件名是original开头的,后缀名不限定的文件,?!original 代表反向选择
        <!-- <exclude expression="abc"></exclude>
        <exclude expression="image"></exclude>
        <exclude expression="txt"></exclude>
        <exclude expression="xml"></exclude>
        <exclude expression="*"></exclude>
        -->
      </filter>
      <inotify>
        <delete start="false"/>                                      #不监控文件或目录的删除
        <createFolder start="true"/>              #监控目录的创建
        <modify start="true"/>                                      #监控文件的修改
        <createFile start="true"/>                            #监控创建新文件
        <closeWrite start="false"/>
        <moveFrom start="false"/>
        <moveTo start="false"/>
        <attrib start="false"/>
      </inotify>

      <sersync>
        <localpath watch="/data/bookfm/doc/book">    #设置监控的目录
                <remote ip="192.168.100.250" name="book"/>  
                                                                                                       
#指定目标主机的IP地址和模块名(和samba的类似,不是目录的名称)
                                                                                                   
#有几台目标主机,配置这样几条,同时也要在目标上启用rsync守护进程
                <!--<remote ip="192.168.8.39" name="tongbu"/>-->
                <!--<remote ip="192.168.8.40" name="tongbu"/>-->
        </localpath>
        <rsync>
                <commonParams params="-au"/>    #指定rsync 运行时的参数,可根据自身需要更改
                <auth start="true" users="bookbackup" passwordfile="/usr/local/GNU-Linux-x86/rsyncd.secrets"/>
            #启用验证,指定用户名和密码文件(只用写一个密码即可)
            #用户名是目标服务器上rsync配置文件中指定的用户名,密码文件中的密码也目标服务器上rsync指定的密码文件指定的密码
                <userDefinedPort start="false" port="874"/><!-- port=874 -->
                <timeout start="false" time="100"/><!-- timeout=100 -->
                <ssh start="false"/>
        </rsync>
        <failLog path="/var/rsync/rsync_error.log" timeToExecute="60"/><!--default every 60mins execute once-->
                                                                                                                                                                                                                #指定错误的日志文件路径
        <crontab start="false" schedule="600"><!--600mins-->
                <crontabfilter start="false">
                  <exclude expression="*.php"></exclude>
                  <exclude expression="info/*"></exclude>
                </crontabfilter>
        </crontab>
        <plugin start="false" name="command"/>
      </sersync>

      <plugin name="command">
        <param prefix="/bin/sh" suffix="" ignoreError="true"/>        <!--prefix /opt/tongbu/mmm.sh suffix-->
        <filter start="false">
                <include expression="(.*).php"/>
                <include expression="(.*).sh"/>
        </filter>
      </plugin>

      <plugin name="socket">
        <localpath watch="/opt/tongbu">
                <deshost ip="192.168.138.20" port="8009"/>
        </localpath>
      </plugin>
      <plugin name="refreshCDN">
        <localpath watch="/data0/htdocs/cms.xoyo.com/site/">
                <cdninfo domainname="ccms.chinacache.com" port="80" username="xxxx" passwd="xxxx"/>
                <sendurl base="http://pic.xoyo.com/cms"/>
                <regexurl regex="false" match="cms.xoyo.com/site([/a-zA-Z0-9]*).xoyo.com/images"/>
        </localpath>
      </plugin>
</head>
配置文件一般根据自己需要修改





sersync +rsync实现数据实时步 主机A 装sersync数据源,源机器)192.168.0.63 主机B装rsync (备份端,目标机器)192.168.0.64 实验结果:主机A进行新增,修改,删除文件的操作,文件或目录发生了变化,主机B会实时步发生变化的文件或目录。rsync步的时候是对整个目录进行步,数据量大时,效率低,sersync可以监控变化的文件,配合rsync步变化的文件,效率提高。 步过程 在主机A开启sersync服务,配置sersyncsersync会监控配置文件路径中的文件变化 A主机调用rsync客户端命令把变化的文件步到B主机 在B主机配置rsync服务,用来接收A主机的推送命令 A主机解压 tar -xzvf sersync2.5.4.tar.gz -C /opt 把目录改名 mv GNU-Linux-x86 sersync 进入目录 cd /opt/sersync 备份配置文件 cp confxml.xml confxml.xml.bak 修改配置文件  vim confxml.xml <sersync> <localpath watch="/var/www/html"> #本地数据目录。 <remote ip="B主机ip地址" name="wwwroot"/> #B主机rsync 模块名称 users="B主机/etc/rsyncd.conf配置文件中的auth users值" passwordfile="B主机/etc/rsyncd.conf配置文件中的secrets file值" A主机/opt/sersync/confxml.xml配置文件如下图 B主机/etc/rsyncd.conf配置文件如下图 A主机 加载配置文件并启动 /opt/sersync/sersync2 -d -r -o /opt/sersync/confxml.xml A主机检查sersync是否运行  ps aux | grep 'sersync'|grep -v 'grep' A主机sersync成功运行后,B主机的/var/www/html目录下输入 watch ls -l 进行观察 A主机的/var/www/html目录下新建或删除文件等操作,B主机查看步效果 设置sersync开机自动执行 vi /etc/rc.d/rc.local /opt/sersync/sersync2 -d -r -o /opt/sersync/confxml.xml 添加脚本监控 sersync 是否正常运行 vim check_sersync.sh #!/bin/bash sersync="/opt/sersync/sersync2" confxml="/opt/sersync/confxml.xml" status=$(ps aux |grep 'sersync2'|grep -v 'grep'|wc -l) if [ $status -eq 0 ];then         $sersync -d -r -o $confxml & else echo "$sersync已运行无需再次运行" exit 0; fi 给脚本添加执行权限,并添加到定时任务,每周一执行(分,时,日,月,周) chmod +x /opt /check_sersync.sh crontab -e * * * * 1 /opt/check_sersync.sh
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值