亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 應用 > 軟件技巧 > 正文

大量小文件的實時同步的解決方案分析

2024-07-16 17:44:54
字體:
來源:轉載
供稿:網友
傳統的文件同步方案有rsync(單向) 和 unison(雙向)等,它們需要掃描所有文件后進行比對,差量傳輸。如果文件數量達到了百萬甚至千萬量級,掃描所有文件將非常耗時。而且正在發生變化的往往是其中很少的一部分,這是非常低效的方式。

之前看了Amazon的Dynamo的設計文檔,它們每個節點的數據是通過Hash Tree來實現同步,既有通過日志來同步的軟實時特點(msyql, bdb等),也可以保證最終數據的一致性(rsync, unison等)。Hash Tree的大體思路是將所有數據存儲成樹狀結構,每個節點的Hash是其所有子節點的Hash的Hash,葉子節點的Hash是其內容的Hash。這樣一旦某個節點發生變化,其Hash的變化會迅速傳播到根節點。需要同步的系統只需要不斷查詢跟節點的hash,一旦有變化,順著樹狀結構就能夠在logN級別的時間找到發生變化的內容,馬上同步。

文件系統天然的是樹狀結構,盡管不是平衡的數。如果文件的修改時間是可靠的,可以表征文件的變化,那就可以用它作為文件的Hash值。另一方面,文件的修改通常是按順序執行的,后修改的文件比早修改的文件具有更大的修改時間,這樣就可以把一個目錄內的最大修改時間作為它的修改時間,以實現Hash Tree。這樣,一旦某個文件被修改,修改時間的信息就會迅速傳播到根目錄。

一般的文件系統都不是這樣做的,目錄的修改時間表示的是目錄結構最后發生變化的時間,不包括子目錄,否則會不堪重負。因為我們需要自己實現這個功能,利用Linux 2.6內核的新特性inotify獲得某個目錄內文件發生變化的信息,并把其修改時間傳播到它的上級目錄(以及再上級目錄)。Python 有 pyinotify,watch.py的代碼如下:

復制代碼代碼如下:
#!/usr/bin/python
from pyinotify import *
import os, os.path
flags = IN_CLOSE_WRITE|IN_CREATE|IN_Q_OVERFLOW
dirs = {}
base = '/log/lighttpd/cache/images/icon/u241'
base = 'tmp'
class UpdateParentDir(ProcessEvent):
def process_IN_CLOSE_WRITE(self, event):
print 'modify', event.pathname
mtime = os.path.getmtime(event.pathname)
p = event.path
while p.startswith(base):
m = os.path.getmtime(p)
if m < mtime:
print 'update', p
os.utime(p, (mtime,mtime))
elif m > mtime:
mtime = m
p = os.path.dirname(p)
process_IN_MODIFY = process_IN_CLOSE_WRITE
def process_IN_Q_OVERFLOW(self, event):
print 'over flow'
max_queued_events.value *= 2
def process_default(self, event):
pass
wm = WatchManager()
notifier = Notifier(wm, UpdateParentDir())
dirs.update(wm.add_watch(base, flags, rec=True, auto_add=True))
notifier.loop()

在已經有Hash Tree的時候,同步就比較簡單了,不停地獲取根目錄的修改時間并順著目錄結構往下找即可。需要注意的是,在更新完文件后,需要設置修改時間為原文件的修改時間,目錄也是,保證Hash Tree的一致性,否則沒法同步。mirror.py的代碼如下 
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩激情视频| 国产精品视频99| 国产精品美女免费看| 91久久国产综合久久91精品网站| 日韩精品一区二区三区第95| 欧美性videos高清精品| 国产一区二区免费| 91手机视频在线观看| 成人亚洲欧美一区二区三区| 欧美国产日产韩国视频| www.亚洲一区| 疯狂做受xxxx高潮欧美日本| 色偷偷888欧美精品久久久| 国产成人精品免高潮在线观看| 97视频在线观看播放| 精品福利免费观看| 国产精品99蜜臀久久不卡二区| 久久久国产成人精品| 日韩av电影在线播放| 欧美在线www| 日韩美女av在线免费观看| 欧美老女人www| 欧美日韩中国免费专区在线看| 国产一区av在线| 亚洲国产精品久久久| 国模私拍视频一区| 久久精品夜夜夜夜夜久久| 欧美午夜视频一区二区| 亚洲毛片在线免费观看| 国产精品丝袜久久久久久不卡| 欧美成年人视频网站欧美| 国产精品久久久久久久久免费| 欧美国产精品va在线观看| 久久久久久久激情视频| 亚洲精品国产免费| 国产欧美在线视频| 日韩精品免费观看| 国产精品流白浆视频| 有码中文亚洲精品| 日本一区二区在线免费播放| 欧美激情国产日韩精品一区18| 一本色道久久88综合日韩精品| 亚洲第一国产精品| 日本精品免费一区二区三区| 亚洲色图日韩av| 亚洲网站在线播放| 精品福利樱桃av导航| 揄拍成人国产精品视频| 精品电影在线观看| 精品视频一区在线视频| 日本成人精品在线| 久久久久久久一区二区三区| 久久夜色精品国产欧美乱| 日韩欧美亚洲一二三区| 国产成人在线亚洲欧美| 97热在线精品视频在线观看| 欧洲午夜精品久久久| 91精品国产99久久久久久| 国产一区欧美二区三区| 欧美乱大交xxxxx另类电影| 亚洲电影成人av99爱色| 亚洲精品福利免费在线观看| 欧美影院久久久| 91精品久久久久久久久中文字幕| 亚洲精品在线视频| 欧美激情国产精品| 亚洲xxxx妇黄裸体| 亚洲自拍小视频免费观看| 97精品一区二区视频在线观看| 欧美插天视频在线播放| 91精品在线国产| 欧美日韩综合视频| 亚洲男人第一av网站| 亚洲精品日韩在线| 亚洲色图35p| 国产一区二中文字幕在线看| 狠狠躁天天躁日日躁欧美| 国产97在线视频| 国产成人精品午夜| 欧美怡春院一区二区三区| 久久久99免费视频| 日韩在线视频一区| 久久精品亚洲热| www.欧美三级电影.com| 91日本在线观看| 亚洲精品福利视频| 日韩av手机在线看| 69国产精品成人在线播放| 国产亚洲精品久久久| 国产精品嫩草影院一区二区| 中文字幕精品久久| 亚洲精品国产拍免费91在线| 亚洲美女黄色片| 精品久久久在线观看| 欧美不卡视频一区发布| 亚洲国产成人精品久久| 欧美专区中文字幕| 亚洲精品美女久久久| 亚洲自拍另类欧美丝袜| 亚洲电影免费观看高清完整版在线观看| 色综合久久天天综线观看| 国内精品小视频| 国产精品久久久久aaaa九色| 欧美巨乳在线观看| 久久亚洲精品小早川怜子66| 精品国产欧美一区二区五十路| 国产精品日本精品| 成人精品一区二区三区电影黑人| 亚洲欧美自拍一区| 久久婷婷国产麻豆91天堂| 欧美视频国产精品| 亚洲一区二区三区sesese| 97精品视频在线播放| 91视频国产高清| 亚洲精品日韩欧美| 亚洲人午夜色婷婷| 亚洲国产精品一区二区久| 久久免费视频网站| 中文字幕亚洲一区在线观看| 国产精品99蜜臀久久不卡二区| 狠狠久久五月精品中文字幕| 亚洲一区二区三| 中文字幕在线亚洲| www.日韩免费| 在线观看国产欧美| 日韩电影大片中文字幕| 亚洲精品综合精品自拍| 中文字幕少妇一区二区三区| 91久久国产精品91久久性色| 久久99精品久久久久久琪琪| www.99久久热国产日韩欧美.com| 欧美在线性爱视频| 欧美亚洲成人免费| 欧美精品一区二区三区国产精品| 国产精品第一第二| 成人久久一区二区| 国产福利精品在线| 日本精品久久久久影院| 中文字幕少妇一区二区三区| 91欧美精品午夜性色福利在线| 2019亚洲男人天堂| 国产一区二区在线播放| 欧美国产在线电影| 91久久在线播放| 日韩一区二区三区xxxx| 久久久久九九九九| 国产精品久久久久免费a∨大胸| 91高清视频免费观看| 亚洲xxxx18| 国产一区二区成人| 欧美精品一区二区三区国产精品| 欧美国产视频日韩| 国产欧美日韩中文| 国产精品xxx视频| 国产欧美日韩91| 亚洲综合在线播放| 亚洲综合最新在线| 日韩美女视频免费看| 精品中文字幕乱| 日韩美女在线观看一区| 国产精品天天狠天天看| 欧美壮男野外gaytube| 欧美日韩免费观看中文| 69国产精品成人在线播放|