[sersync+rsync] 文件同步部署實戰

  針對本地文件的修改,自動同步到遠程文件夾,遠程備份很方面。研究了下你們的主流同步方案通常是 rsync+inotify和rsync+sersync, 本文這裏使用sersync的方案作爲實驗。php


基本大綱:mysql

  1.基本原理概述linux

  2.實驗環境準備git

  3.實驗的操做步驟以及結論github

  




一:基本原理概述web

  我這裏的目的是爲了遠程同步mysql的備份文件,centos6.6 主機同步到另外一臺centos6.6主機
正則表達式

  使用rsync+sersync作實時同步時,用於推送文件 的服務器運行sersync服務,用於接收文件的服務器則運行rsync守護進程,簡單來講就是sersync會利用rsync命令將文件推送到 rsync服務器,實際線上使用通常會把sersync做爲主服務器,rsync做爲鏡像服務器,實現數據同步備份,web鏡像等功能
sql

  因此兩臺機器都須要rsync, 而後有對應的寫數據權限。
express




二:實驗環境準備
centos

  1.操做系統 centos6.6 x86

  2.rsync yum源

  3.sersync2.5_64bit軟件包

  4.推送源機A 192.168.1.8(ip均爲實驗僞造)

  5.接收機B 192.168.1.35

  6.把A機器上的一個目錄下文件的變化同步到B機器上,兩邊文件保持一致。 

  7.接收機B selinux與iptables自行設置好,rsync的端口兩邊要配置一致,默認是873




三:實驗的操做步驟以及結論

接收機上的操做:

一、查看rsync是否安裝
[root@localhost ~]# rpm -qa | grep rsync
rsync-3.0.6-12.el6.x86_64
#若是沒有安裝 yum install -y rsync 就好了
二、rsync配置
[root@localhost ~]# cat /etc/rsyncd.conf 
uid = root
gid = root
use chroot =no
list = no
log file = /var/log/rsyncd.log
[rsyncmysql]
path=/data/backup/ywximysql
comment=rsyncmysql
ignore errors
read only=no
list=no
max connections=200
timeout=600
auth users=rsync
secrets file=/etc/rsync.passwd
hosts allow=*
#host deny=0.0.0.0/0

配置文件註解:
secrets file 這個是配置同步的密碼文件的。
[rsynctest] 這個是配置同步模塊的名稱,後面會用
path 是配置同步的目錄
hosts allow 是容許同步的主機 這裏是測試就沒有限制
hosts deny 拒絕同步的主機

三、建立同步的用戶與密碼的文件,即上圖中的secrets file這個配置選項中的文件。/etc/rsync.passwd,同進要設置這個文件的權限爲600
[root@localhost ~]# echo "rsync:123456ywxi" >> /etc/rsync.passwd
[root@localhost ~]# chmod 600 /etc/rsync.passwd 

四、建立同步的目錄:即上面中path配置選項中的目錄
[root@localhost ~]# mkdir -p /data/backup/ywximysql

五、啓動rsync
[root@localhost ~]# rsync --daemon --config=/etc/rsyncd.conf 
[root@localhost ~]# ps -ef | grep rsync
root      3358     1  0 14:37 ?        00:00:00 rsync --daemon --config=/etc/rsyncd.conf
root      3360  3184  0 14:37 pts/1    00:00:00 grep rsync

接着重啓一下xinetd使得配置生效
[root@localhost ~]# /etc/init.d/xinetd restart
Stopping xinetd: [FAILED]
Starting xinetd: [  OK  ]
這裏是經過 xinetd 服務來重啓rsync,也能夠不用這種方式,若是沒有能夠用yum直接安裝

六、配置開機啓動
[root@localhost ~]# echo "rsync --daemon --config=/etc/rsyncd.conf" >> /etc/rc.d/rc.local


推送源機上的操做:

一、先到sersync 官網的地址已經不能使用了,我從網上找了一份放到其餘地址, github上的源碼鏡像 
我把二進制包下載也放到了上面

#命令集以下:
 wget --no-check-certificate https://raw.githubusercontent.com/orangle/sersync/master/release/sersync2.5.4_64bit_binary_stable_final.tar.gz
 mkdir /usr/local/sersync
 mkdir /usr/local/sersync/conf
 mkdir /usr/local/sersync/bin
 mkdir /usr/local/sersync/log
 tar zxvf sersync2.5.4_64bit_binary_stable_final.tar.gz
 cd GNU-Linux-x86/
 cp confxml.xml /usr/local/sersync/conf
 cp sersync2 /usr/local/sersync/bin
 
二、建立密碼文件,同B服務器同樣,不過這個文件只要保存一個密碼就好了,不用用戶名,權限也是600
[root@localhost tools]# echo "123456ywxi" >> /etc/rsync.passwd      
[root@localhost tools]# chmod 600 /etc/rsync.passwd

三、配置sersync,配置文件就是上第二步複製的confxml.xml這個文中,路徑在/usr/local/sersync/conf中
[root@localhost conf]# cat confxml.xml 
<?xml version="1.0" encoding="ISO-8859-1"?>
<head version="2.5">
   # 設置本地IP和端口
   <host hostip="localhost" port="8008"></host>
   # 開啓DUBUG模式  
   <debug start="false"/>
   # 開啓xfs文件系統
   <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="true"/>
       <closeWrite start="true"/>
       <moveFrom start="true"/>
       <moveTo start="true"/>
       <attrib start="true"/>
       <modify start="true"/>
   </inotify>
   <sersync>
   # 本地同步的目錄路徑
       <localpath watch="/home/data">
   # 遠程IP和rsync模塊名 
           <remote ip="192.168.1.35" name="rsyncmysql"/>  
           <!--<remote ip="192.168.8.39" name="tongbu"/>-->
           <!--<remote ip="192.168.8.40" name="tongbu"/>-->
       </localpath>
       <rsync>
   # rsync指令參數
           <commonParams params="-auvzP"/>
   # rsync同步認證
           <auth start="true" users="rsync" passwordfile="/etc/rsync.pas"/>
   # 設置rsync遠程服務端口,遠程非默認端口則需打開自定義
           <userDefinedPort start="false" port="873"/><!-- port=874 -->
   # 設置超時時間
           <timeout start="true" time="100"/><!-- timeout=100 -->
   # 設置rsync+ssh加密傳輸模式,默認關閉,開啓需設置SSH加密證書
           <ssh start="false"/>
       </rsync>
    # sersync傳輸失敗日誌腳本路徑,每隔60會從新執行該腳本,執行完畢會自動清空。
       <failLog path="/usr/local/sersync/log/rsync_fail_log.sh" timeToExecute="60"/><!--default every 60mins execute once-->
    # 設置rsync+crontab定時傳輸,默認關閉
       <crontab start="false" schedule="600"><!--600mins-->
           <crontabfilter start="false">
               <exclude expression="*.php"></exclude>
               <exclude expression="info/*"></exclude>
           </crontabfilter>
       </crontab>
   # 設置sersync傳輸後調用name指定的插件腳本,默認關閉
       <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="xxx"/>
           <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>

四、建立同步目錄:
mkdir /home/data

五、 設置環境變量:
echo "export PATH=$PATH:/usr/local/sersync/bin/" >> /etc/profile
source /etc/profile
 
六、 啓動sersync
sersync2 -r -d -o /usr/local/sersync/conf/confxml.xml
#重啓操做以下:
# killall sersync2 && sersync2 -r -d -o /usr/local/sersync/conf/confxml.xml

七、 設置開機啓動
echo "sersync2 -r -d -o /usr/local/sersync/conf/confxml.xml" >> /etc/rc.local


啓動了sersync服務以後

推送源機操做:

[root@localhost ~]# cd /home/data/

[root@localhost data]# ls

[root@localhost data]# touch backup.sql

[root@localhost data]# touch test.sql

[root@localhost data]# ll

total 0

-rw-r--r-- 1 root root 0 Jun  5 06:00 backup.sql

-rw-r--r-- 1 root root 0 Jun  5 06:15 test.sql

[root@localhost data]# echo "ywxitest" >> test.sql 


接收機操做:

[root@localhost ywximysql]# ll

total 0

-rw-r--r--. 1 root root 0 Jun  5 06:00 backup.sql

-rw-r--r--. 1 root root 0 Jun  5 06:15 test.sql

[root@localhost ywximysql]# cat test.sql 

ywxitest


實驗結論 :

能夠看到文件很快的就被同步到遠程機器上了,文件建立時間一致,實驗成功。

相關文章
相關標籤/搜索