[sersync+rsync] 文件同步部署實戰
基本大綱:
1.基本原理概述
2.實驗環境準備
3.實驗的操作步驟以及結論
一:基本原理概述
我這裏的目的是為了遠程同步mysql的備份文件,centos6.6 主機同步到另一臺centos6.6主機
使用rsync+sersync做實時同步時,用於推送文件 的服務器運行sersync服務,用於接收文件的服務器則運行rsync守護進程,簡單來說就是sersync會利用rsync命令將文件推送到 rsync服務器,實際線上使用一般會把sersync作為主服務器,rsync作為鏡像服務器,實現數據同步備份,web鏡像等功能
所以兩臺機器都需要rsync, 然後有對應的寫數據權限。
二:實驗環境準備
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
三:實驗的操作步驟以及結論
接收機上的操作:
1、查看rsync是否安裝 [root@localhost ~]# rpm -qa | grep rsync rsync-3.0.6-12.el6.x86_64 #如果沒有安裝 yum install -y rsync 就行了 2、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 拒絕同步的主機 3、創建同步的用戶與密碼的文件,即上圖中的secrets file這個配置選項中的文件。/etc/rsync.passwd,同進要設置這個文件的權限為600 [root@localhost ~]# echo "rsync:123456ywxi" >> /etc/rsync.passwd [root@localhost ~]# chmod 600 /etc/rsync.passwd 4、創建同步的目錄:即上面中path配置選項中的目錄 [root@localhost ~]# mkdir -p /data/backup/ywximysql 5、啟動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直接安裝 6、配置開機啟動 [root@localhost ~]# echo "rsync --daemon --config=/etc/rsyncd.conf" >> /etc/rc.d/rc.local
推送源機上的操作:
1、先到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 2、創建密碼文件,同B服務器一樣,不過這個文件只要保存一個密碼就行了,不用用戶名,權限也是600 [root@localhost tools]# echo "123456ywxi" >> /etc/rsync.passwd [root@localhost tools]# chmod 600 /etc/rsync.passwd 3、配置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> 4、創建同步目錄: mkdir /home/data 5、 設置環境變量: echo "export PATH=$PATH:/usr/local/sersync/bin/" >> /etc/profile source /etc/profile 6、 啟動sersync sersync2 -r -d -o /usr/local/sersync/conf/confxml.xml #重啟操作如下: # killall sersync2 && sersync2 -r -d -o /usr/local/sersync/conf/confxml.xml 7、 設置開機啟動 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
實驗結論 :
可以看到文件很快的就被同步到遠程機器上了,文件創建時間一致,實驗成功。
[sersync+rsync] 文件同步部署實戰