欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Sersync+Rsync實(shí)現(xiàn)觸發(fā)式文件同步實(shí)戰(zhàn)過(guò)程

 更新時(shí)間:2017年09月15日 16:51:45   作者:PeanutLike  
sersync是使用c++編寫(xiě),而且對(duì)linux系統(tǒng)文 件系統(tǒng)產(chǎn)生的臨時(shí)文件和重復(fù)的文件操作進(jìn)行過(guò)濾。下面通過(guò)本文給大家分享Sersync+Rsync實(shí)現(xiàn)觸發(fā)式文件同步實(shí)戰(zhàn)過(guò)程,需要的朋友參考下吧

背景

  通常我們?cè)诜?wù)器上使用rsync加上crontab來(lái)定時(shí)地完成一些同步、備份文件的任務(wù)。隨著業(yè)務(wù)和應(yīng)用需求的不斷擴(kuò)大、實(shí)時(shí)性要求越來(lái)越高。一般rsync是通過(guò)校驗(yàn)所有文件后,進(jìn)行差量同步,如果文件量十分龐大,那么rsync進(jìn)行校驗(yàn)的過(guò)程也是十分耗時(shí)的。而且正在發(fā)生變化的往往是其中很少的一部分,這是非常低效的方式。其次,rsync不能實(shí)時(shí)的去監(jiān)測(cè)、同步數(shù)據(jù),雖然它可以通過(guò)crontab方式進(jìn)行觸 發(fā)同步,但是兩次觸發(fā)動(dòng)作一定會(huì)有時(shí)間差,這樣就導(dǎo)致了服務(wù)端和客戶端數(shù)據(jù)可能出現(xiàn)不一致,無(wú)法在應(yīng)用故障時(shí)完全的恢復(fù)數(shù)據(jù)。而Sersync+Rsync的組合能夠較好地解決這種問(wèn)題。

Sersync介紹

1、sersync是使用c++編寫(xiě),而且對(duì)linux系統(tǒng)文 件系統(tǒng)產(chǎn)生的臨時(shí)文件和重復(fù)的文件操作進(jìn)行過(guò)濾(詳細(xì)見(jiàn)附錄,這個(gè)過(guò)濾腳本程序沒(méi)有實(shí)現(xiàn)),所以在結(jié)合rsync同步的時(shí)候,節(jié)省了運(yùn)行時(shí)耗和網(wǎng)絡(luò)資源。 因此更快。

2、sersync配置起來(lái)很簡(jiǎn)單,其中bin目錄下已經(jīng)有基本上靜態(tài)編譯的2進(jìn)制文件,配合bin目錄下的xml配置文件直接使用即可。

3、另外本項(xiàng)目相比較其他腳本開(kāi)源項(xiàng)目,使用多線程進(jìn)行同步,尤其在同步較大文件時(shí),能夠保證多個(gè)服務(wù)器實(shí)時(shí)保持同步狀 態(tài)。

4、本項(xiàng)目有出錯(cuò)處理機(jī)制,通過(guò)失敗隊(duì)列對(duì)出錯(cuò)的文件重新同步,如果仍舊失敗,則每10個(gè)小時(shí)對(duì)同步失敗的文件重新同步。

5、本項(xiàng)目自帶crontab功能,只需在xml配置文件中開(kāi)啟,即可按您的要求,隔一段時(shí)間整體同步一次。無(wú)需再額外配置crontab功能。

6、本項(xiàng)目socket與http插件擴(kuò)展,滿足您二次開(kāi)發(fā)的需要。

實(shí)戰(zhàn)過(guò)程

一、服務(wù)器環(huán)境

服務(wù)端:172.16.57.26 centos6.7 rsync-server 接收文件

客戶端:172.16.57.25 centos6.7 sersync+rsync-client 發(fā)送文件

二、服務(wù)端安裝rsync-server

1、安裝rsync

# rpm -qa | grep rsync #查看rsync是否已經(jīng)安裝,如果沒(méi)有安裝,yum install直接安裝即可

2、使用xinetd方式啟動(dòng)rsync

# vim /etc/xinetd.d/rsync #修改disable = no,flags = IPv4

3、修改rsync配置文件

# mkdir /etc/rsyncd
# vim /etc/rsyncd/rsyncd.conf #修改配置文件如下
# GLOBAL OPTIONS
motd file=/etc/motd
port=873
pid file=/var/run/rsyncd.pid
lock file = /var/lock/rsyncd
log file=/var/log/rsyncd
transfer logging = yes
log format = [op]:%o [ip]:%a [module]:%m [path]:%P [file]:%f [size]:%l
syslog facility=daemon
max connections=100
[recv]
comment = "recv data from 57.25"
path = /opt/rsync_data/recv #這邊的目錄的宿主要改為apprun,在這里同步過(guò)程中使用的是普通賬戶apprun
list = yes
use chroot = yes
uid = apprun
gid = apprun
read only = no
write only = no
exclude =
include =
auth users = rsync
secrets file = /etc/rsyncd/rsyncd.secrets
strict modes = yes
hosts allow = 172.16.57.25
hosts deny = *
# ln -s /etc/rsyncd/rsyncd.conf /etc/rsyncd.conf

4、建立用戶認(rèn)證文件

# vim /etc/rsyncd/rsyncd.secrets
rsync:111111   #格式  用戶名:口令
#chmod 600 /etc/rsyncd/rsyncd.secrets #權(quán)限設(shè)為600,否則啟動(dòng)會(huì)報(bào)錯(cuò)

5、啟動(dòng)rsync

# /etc/init.d/xinetd start
# netstat -tpln | grep 873 #查看873端口是否已經(jīng)在監(jiān)聽(tīng)了

三、客戶端安裝sersync+rsync-client

1、安裝rsync,和服務(wù)端一樣,沒(méi)有安裝的話yum install安裝

2、安裝sersync

# tar xzvf sersync2.5_64bit_binary_stable_final.tar.gz
# mv GNU-Linux-x86 /opt/programs/sersync #解壓并拷貝到安裝目錄

3、配置sersync

<?xml version="1.0" encoding="ISO-8859-1"?>
<head version="2.5">
  <host hostip="localhost" 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="true"/>
  <closeWrite start="true"/>
  <moveFrom start="true"/>
  <moveTo start="true"/>
  <attrib start="true"/>
  <modify start="true"/>
  </inotify>
  <sersync>
  <localpath watch="/opt/rsync_data/send"> #監(jiān)控目錄,一旦本地目錄有文件變化,將同步到服務(wù)端
    <remote ip="172.16.57.26" name="recv"/>#服務(wù)端ip和同步模塊
  </localpath>
  <rsync>
    <commonParams params="-artuz"/> #rsync同步參數(shù)
    <auth start="true" users="rsync" passwordfile="/etc/rsync.pas"/>?。7?wù)端認(rèn)證密碼
    <userDefinedPort start="false" port="873"/>
    <timeout start="false" time="100"/><!-- timeout=100 -->
    <ssh start="false"/>
  </rsync>
  <failLog path="/tmp/rsync_fail_log.sh" 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>
</head>

4、服務(wù)端密碼認(rèn)證

# vim /etc/rsync.pas #在相應(yīng)的目錄下配置身份驗(yàn)證文件,里面輸入服務(wù)端的密碼,并chmod 600
# chmod 600 /etc/rsync.pas

5、啟動(dòng)sersync

# ./sersync2 -d -o confxml.xml

四、測(cè)試認(rèn)證

在客戶端下監(jiān)控目錄/opt/rsync_data/send下添加文件或者刪除,服務(wù)端的接受目錄都會(huì)實(shí)時(shí)地進(jìn)行更新。

在此例中,服務(wù)器iptables和selinux均處于關(guān)閉狀態(tài)。

note: 這種方法同步文件的時(shí)候,同步文件的數(shù)量如果很多,可能會(huì)有部分文件在同步過(guò)程中缺失。查閱相關(guān)資料后,找到了如下的解決方案。由于本例中,使用的是xinetd方式啟動(dòng)的rsync服務(wù),在xinetd的配置文件中,修改幾個(gè)參數(shù)如下:

# vim /etc/xinetd.conf

修改幾個(gè)參數(shù):

 cps       = 500 30
 instances    = UNLIMITED
 per_source   = UNLIMITED

總結(jié)

以上所述是小編給大家介紹的Sersync+Rsync實(shí)現(xiàn)觸發(fā)式文件同步,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 離線安裝visual?studio2022+QT5.12的實(shí)現(xiàn)步驟

    離線安裝visual?studio2022+QT5.12的實(shí)現(xiàn)步驟

    近期有需求離線配置C++與QT環(huán)境,本文主要介紹了離線安裝visualstudio2022+QT5.12的實(shí)現(xiàn)步驟,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-06-06
  • c++string字符串的比較是否相等問(wèn)題

    c++string字符串的比較是否相等問(wèn)題

    這篇文章主要介紹了c++string字符串的比較是否相等問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • C++數(shù)組指針和二維數(shù)組詳情

    C++數(shù)組指針和二維數(shù)組詳情

    這篇文章主要介紹了C++數(shù)組指針和二維數(shù)組,指針數(shù)組和二維數(shù)組在應(yīng)用中常用于函數(shù)傳參,下面我們就來(lái)看看指針數(shù)組和二維數(shù)組在應(yīng)用中的具體使用吧,需要的朋友可以參考一下
    2021-10-10
  • TypeScript的函數(shù)定義與使用案例教程

    TypeScript的函數(shù)定義與使用案例教程

    這篇文章主要介紹了TypeScript的函數(shù)定義與使用案例教程,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++的new和delete使用示例詳解

    C++的new和delete使用示例詳解

    這篇文章主要為大家介紹了C++的new和delete使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • 詳解C++中的數(shù)據(jù)抽象

    詳解C++中的數(shù)據(jù)抽象

    這篇文章主要介紹了詳解C++中的數(shù)據(jù)抽象,數(shù)據(jù)抽象是指,只向外界提供關(guān)鍵信息,并隱藏其后臺(tái)的實(shí)現(xiàn)細(xì)節(jié),即只表現(xiàn)必要的信息而不呈現(xiàn)細(xì)節(jié),需要的朋友可以參考下
    2023-05-05
  • 基于QT的TCP通信服務(wù)的實(shí)現(xiàn)

    基于QT的TCP通信服務(wù)的實(shí)現(xiàn)

    在項(xiàng)目開(kāi)發(fā)過(guò)程中,很多地方都會(huì)用到TCP通信,本文主要介紹了基于QT的TCP通信服務(wù)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • 解析C++中的字符串處理函數(shù)和指針

    解析C++中的字符串處理函數(shù)和指針

    這篇文章主要介紹了解析C++中的字符串處理函數(shù)和指針,是C++入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-09-09
  • epoll封裝reactor原理剖析示例詳解

    epoll封裝reactor原理剖析示例詳解

    這篇文章主要為大家介紹了epoll封裝reactor原理剖析示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • C語(yǔ)言實(shí)現(xiàn)電影院選座管理系統(tǒng)

    C語(yǔ)言實(shí)現(xiàn)電影院選座管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)電影院選座管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-12-12

最新評(píng)論