一、Sersync安装

  (1)Sersync同步需求逻辑图

     Sersync依赖于rsync进行数据同步,需在主服务器master上开启Sersync,Sersync负责监控配置文件

中的文件系统的事件变化,然后调用rsync命令把更新的文件同步到目标服务器slave上。

 结论:需要在主服务器上配置Sersync,在同步目标服务器上安装rsync-server。

          Sersync同步示意图

  user----}Sersync--------}S1-rsync服务器

            服务器--------}S2-rsync服务器

     用户user会实时的往Sersync服务器写入或更新数据文件,此时,需要在左边的同步服务器上配置Sersync,在右边的同步目标服务器S1和S2上配置rsync守护进程服务,这样在主服务器写入或更新数据文件时,就会被

     Sersync实时同步到slave服务器S1和S2。

     结论: Sersync就是监控本地的数据写入或更新事件,然后调用rsync客户端命令,将写入或更新的文件实时同步到slave服务器S1和S2上。

  

  

   (2)检查版本---安装--升级版本   yum -y install rsync  也可编译安装

    

   (3)在目录服务器slave服务器S1和S2上配置。

   ################配置客户端S1-S2######################

[root@rsync-s1 ~]# cat /etc/rsyncd.conf 

#rsync_config_______________start

#create by tangbo 2015-12-02 13:25

#QQ7313760

#########rsyncd.conf______start#########


uid = root

gid = root

use chroot = no

max connections = 200

timeout = 300

pid file =  /var/run/rsyncd.pid

lock file = /var/run/rsync.lock

log file = /var/log/rsyncd.log

ignore errors

read only = false

#write only = no

hosts allow = 192.168.11.0/24

hosts deny = 0.0.0.0/32

list = false

auth users = rsync_backup

secrets file = /etc/rsync.password


#####################################

[www]

path=/data/www/www/

comment = www by tangbo 13:40 2015-11-20

#####################################

[bbs]

path=/data/www/bbs/

comment = www by tangbo 13:40 2015-11-20

#####################################

[blog]

path=/data/www/blog/

comment = www by tangbo 13:40 2015-11-20

###################################

#########rsyncd.conf______end#########

[root@rsync-s1 ~]# 

上面的rsync服务的配置文件,允许Sersync主服务器访问,rsync同步的模块名为[www] [bbs][blog]

将同步过来的文件分别放入对应path指定的目录/data/www/www/ /data/www/bbs/ /data/www/blog/下,如果有多台目标服务器,则每台都需要类似配置,uid,gid可根据实际情况变化。该用户必须对这三个目录有写入权限。

   

   (4)创建相关目录:

      [root@rsync-s2 ~]# mkdir -p /data/www/www/ /data/www/bbs/ /data/www/blog/

      [root@rsync-s2 ~]# ls /data/www/

        bbs  blog  www

      [root@rsync-s2 ~]# 

  权限相关配置:

      [root@rsync-s1 ~]# vim /etc/rsync.password 

       rsync_backup:tangbo  (这个用户和密码需要去创建)

      [root@rsync-s1 ~]# chmod 600 /etc/rsync.password 

  检查:

     [root@rsync-s1 ~]# cat /etc/rsync.password 

     rsync_backup:tangbo

     [root@rsync-s1 ~]# ll /etc/rsync.password 

      -rw-------. 1 root root 20 Dec  8 21:54 /etc/rsync.password

     [root@rsync-s1 ~]#  

   配置完成后,以守护进程方式启动rsync服务。

   [root@rsync-s1 ~]# pkill rsync

   [root@rsync-s1 ~]# rsync --daemon

   [root@rsync-s1 ~]# netstat -tlnp | grep 873

    tcp        0      0 0.0.0.0:873                 0.0.0.0:*                   LISTEN      888/rsync           

    tcp        0      0 :::873                      :::*                        LISTEN      888/rsync           

   [root@rsync-s1 ~]# 

  (5)设置开机自启动

     [root@rsync-s1 ~]# echo "#rsync service daemon by tangbo 20151207" >>/etc/rc.local 

     [root@rsync-s1 ~]# echo "/usr/bin/rsync --daemon" >>/etc/rc.local 

     [root@rsync-s1 ~]# grep daemon /etc/rc.local 

      #rsync service daemon by tangbo 20151207

      /usr/bin/rsync --daemon

     [root@rsync-s1 ~]# 

 重启命令: 

     [root@rsync-s2 ~]# pkill rsync

     [root@rsync-s2 ~]# netstat -tlnp

Active Internet connections (only servers)

Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID/Program name   

tcp        0      0 0.0.0.0:22                  0.0.0.0:*                   LISTEN      22616/sshd          

tcp        0      0 127.0.0.1:25                0.0.0.0:*                   LISTEN      1258/master         

tcp        0      0 :::22                       :::*                        LISTEN      22616/sshd          

tcp        0      0 ::1:25                      :::*                        LISTEN      1258/master         

tcp        0      0 :::3306                     :::*                        LISTEN      5210/mysqld         

 [root@rsync-s2 ~]# /usr/bin/rsync --daemon

   自己可以写一个正常的rsync启动脚本。

  

三、Master端安装rsync客户端并且测试    yum -y install rsync  也可编译安装

   

   (1)在Master上配置相关权限认证

   [root@openvpn ~]# echo "tangbo" >/etc/rsysn.password

   [root@openvpn ~]# chmod 600 /etc/rsync.password 

   [root@openvpn ~]# chmod 600 /etc/rsync.password 

   [root@openvpn ~]# cat /etc/rsync.password 

    tangbo

    [root@openvpn ~]# ll /etc/rsync.password 

    -rw------- 1 root root 7 Dec  8 22:09 /etc/rsync.password

    [root@openvpn ~]# 

     启动服务:

[root@openvpn ~]# touch /etc/rsyncd.conf

     [root@openvpn ~]# rsync --daemon

     [root@openvpn ~]# netstat -tlnp

   (2)master 上手工测试同步情况:此步骤非常关键,一定要测试。如果测试同步不成功,后面的sersync配置后也不会同步数据。

     [root@rsync-s2 ~]# mkdir -p /data/www/www/ /data/www/bbs/ /data/www/blog/

[root@openvpn ~]# touch /data/www/www/www.log /data/www/bbs/bbs.log /data/www/blog/blog.log

  

   (3)执行同步命令

     [root@openvpn /]# rsync -avzP  /data/www/www/  rsync_backup@192.168.11.34::www/  --password-file=/etc/rsync.password

[root@openvpn /]# rsync -avzP  /data/www/www/  rsync_backup@192.168.11.35::www/  --password-file=/etc/rsync.password

 

[root@openvpn /]# rsync -avzP  /data/www/bbs/  rsync_backup@192.168.11.34::bbs/  --password-file=/etc/rsync.password

[root@openvpn /]# rsync -avzP  /data/www/bbs/  rsync_backup@192.168.11.35::bbs/  --password-file=/etc/rsync.password

 

[root@openvpn /]# rsync -avzP  /data/www/blog/  rsync_backup@192.168.11.35::blog/  --password-file=/etc/rsync.password

[root@openvpn /]# rsync -avzP  /data/www/blog/  rsync_backup@192.168.11.35::blog/  --password-file=/etc/rsync.password

    

上述目录都可以同步成功则可以实现下一步的工作,安装sersync  


四、安装Sersync---单实例

      (1)下载源码且解压到/usr/local/下

 [root@openvpn tools]# tar -zxvf sersync_64bit_binary_stable_final.tar.gz -C /usr/local/

 重命名GNU-Linux-x86/ 为sersync 

 [root@openvpn local]# mv GNU-Linux-x86/ sersync    

 [root@openvpn local]# ls -R sersync/

         sersync/:

         confxml.xml  sersync2

         [root@openvpn local]# 

     

(2)规范sersync目录结构

[root@openvpn local]# cd sersync/

     [root@openvpn sersync]# mkdir -p conf bin logs

[root@openvpn sersync]# mv confxml.xml conf

     [root@openvpn sersync]# mv sersync2 bin

 

[root@openvpn local]# ls -R sersync/

       sersync/:

       bin  conf  logs


       sersync/bin:

       sersync2


       sersync/conf:

       confxml.xml


       sersync/logs:

       [root@openvpn local]# 

 

(3)配置sersync

   首先备份配置文件: [root@openvpn conf]# cp confxml.xml confxml.xml.backup.$(date +%F)

     

(4)更改优化sersync配置

   修改第24行

[root@openvpn conf]# vim +24 confxml.xm

   <sersync>

        <localpath watch="/data/www/www">

            <remote ip="192.168.11.34" name="www"/>

            <remote ip="192.168.11.35" name="www"/>

        <localpath watch="/data/www/bbs">                 只建立一个目录,三个目录要修改配置文件

            <remote ip="192.168.11.34" name="bbs"/>

            <remote ip="192.168.11.35" name="bbs"/>

       <localpath watch="/data/www/blog">

            <remote ip="192.168.11.34" name="blog"/>

            <remote ip="192.168.11.35" name="blog"/>

 提示:此步骤<localpath watch="/data/www/blog">就是定义服务端待同步的目录和目标服务器的模块name="blog"名。

 

(5)修改第34行

      <rsync>

            <commonParams params="-artuz"/>

            <auth start="true" users="rsync_backup" passwordfile="/etc/rsync.password"/>

            <userDefinedPort start="false" port="874"/><!-- port=874 -->

            <timeout start="true" time="100"/><!-- timeout=100 -->

            <ssh start="false"/>

        </rsync>

其实这个修改就是在拼接:

rsync -avzP  /data/www/www/  rsync_backup@192.168.11.34::www/  --password-file=/etc/rsync.password这个同步命令而已。

 

(6)修改第37行--当同步失败后,错误日志存放路径。并且没60分钟对失败的log进行重新同步。

   <failLog path="//usr/local/sersync/logs/rsync_fail_log.sh" timeToExecute="60"/><!--default every 60mins execute once-->

 

#############开启sersync守护进程同步数据######################

(7)配置sersync 环境变量

   [root@openvpn conf]# echo 'export PATH=$PATH:/usr/localsersync/bin'>>/etc/profile

[root@openvpn conf]# tail -l /etc/pro

         profile    profile.d/ protocols  

        [root@openvpn conf]# tail -l /etc/profile

            . "$i"

        else

            . "$i" >/dev/null 2>&1

        fi

    fi

done


unset i

unset -f pathmunge

export PATH=$PATH:/usr/local/sersync/bin

     [root@openvpn conf]# source /etc/profile

 

    (8)测试结果:发现问题,仅仅能同步一个模块的路径,其它模块的路径不能同步。


五、多实例

   (1)复制配置文件

   [root@openvpn conf]# cp confxml.xml www_confxml.xml

   [root@openvpn conf]# cp confxml.xml bbs_confxml.xml

   [root@openvpn conf]# cp confxml.xml blog_confxml.xml

   

   (2)修改配置文件

   [root@openvpn conf]# diff www_confxml.xml bbs_confxml.xml 

24,26c24,26

< <localpath watch="/data/www/www">

<    <remote ip="192.168.11.34" name="www"/> 

<    <remote ip="192.168.11.35" name="www"/>

---

> <localpath watch="/data/www/bbs">

>    <remote ip="192.168.11.34" name="bbs"/> 

>    <remote ip="192.168.11.35" name="bbs"/>

37c37

< <failLog path="/usr/local/sersync/logs/www_rsync_fail_log.sh" timeToExecute="60"/><!--default every 60mins execute once-->

---

> <failLog path="/usr/local/sersync/logs/bbs_rsync_fail_log.sh" timeToExecute="60"/><!--default every 60mins execute once-->

[root@openvpn conf]# 


[root@openvpn conf]# diff www_confxml.xml blog_confxml.xml 

24,26c24,26

< <localpath watch="/data/www/www">

<    <remote ip="192.168.11.34" name="www"/> 

<    <remote ip="192.168.11.35" name="www"/>

---

> <localpath watch="/data/www/blog">

>    <remote ip="192.168.11.34" name="blog"/> 

>    <remote ip="192.168.11.35" name="blog"/>

37c37

< <failLog path="/usr/local/sersync/logs/www_rsync_fail_log.sh" timeToExecute="60"/><!--default every 60mins execute once-->

---

> <failLog path="/usr/local/sersync/logs/blog_rsync_fail_log.sh" timeToExecute="60"/><!--default every 60mins execute once-->

[root@openvpn conf]# 


   (3)多实例初始化同步命令:

   sersync -r -d -o /usr/local/sersync/conf/www_confxml.xml

   sersync -r -d -o /usr/local/sersync/conf/bbs_confxml.xml

   sersync -r -d -o /usr/local/sersync/conf/blog_confxml.xml

   

   (4)检查配置

   [root@openvpn conf]# ps -ef | grep sersync

root     18118     1  0 20:51 ?        00:00:00 sersync -r -d -o /usr/local/sersync/conf/www_confxml.xml

root     18141     1  0 20:51 ?        00:00:00 sersync -r -d -o /usr/local/sersync/conf/bbs_confxml.xml

root     18165     1  0 20:51 ?        00:00:00 sersync -r -d -o /usr/local/sersync/conf/blog_confxml.xml

root     18187 29986  0 20:51 pts/0    00:00:00 grep sersync

root     32204 29986  0 01:49 pts/0    00:00:00 vim sersync2

[root@openvpn conf]# 

   (5)到测试目录下面去测试是否同步成功,同时建立一千个文件

   [root@openvpn tmp]# cat for.sh 

   #!/bin/bash


   for i in `seq 1 1000`

   do

   touch /data/www/www/$i

   touch /data/www/bbs/$i

   touch /data/www/blog/$i

   done

   (6)加入开机自启动

      [root@openvpn tmp]# tail -4 /etc/rc.local 

       tail: inotify cannot be used, reverting to polling

      #sersync boot

      sersync -r -d -o /usr/local/sersync/conf/www_confxml.xml

      sersync -r -d -o /usr/local/sersync/conf/bbs_confxml.xml

      sersync -r -d -o /usr/local/sersync/conf/blog_confxml.xml

      [root@openvpn tmp]#