FastDFS分布式文件系統(tǒng)

FastDFS簡介

?FastDFS是一個輕量級的開源分布式文件系統(tǒng)

?FastDFS主要解決了大容量的文件存儲和高并發(fā)訪問的問題拦坠,文件存取時實現(xiàn)了負載均衡

?FastDFS實現(xiàn)了軟件方式的RAID森渐,可以使用廉價的IDE硬盤進行存儲

?支持存儲服務(wù)器在線擴容

?支持相同內(nèi)容的文件只保存一份伤柄,節(jié)約磁盤空間

?FastDFS只能通過ClientAPI訪問,不支持POSIX訪問方式

?FastDFS特別適合大中型網(wǎng)站使用屯阀,用來存儲資源文件(如:圖片降狠、文檔、音頻溜畅、視頻等等)

系統(tǒng)架構(gòu)-架構(gòu)圖


系統(tǒng)架構(gòu)-上傳文件流程圖


?1. client詢問tracker上傳到的storage捏卓,不需要附加參數(shù);

?2. tracker返回一臺可用的storage慈格;

?3. client直接和storage通訊完成文件上傳怠晴。

系統(tǒng)架構(gòu)-下載文件流程圖


?1. client詢問tracker下載文件的storage,參數(shù)為文件標識(組名和文件名)浴捆;

?2. tracker返回一臺可用的storage蒜田;

?3. client直接和storage通訊完成文件下載。

相關(guān)術(shù)語

?Tracker Server:跟蹤服務(wù)器选泻,主要做調(diào)度工作物邑,在訪問上起負載均衡的作用。記錄storage server的狀態(tài)滔金,是連接Client和Storageserver的樞紐。

?Storage Server:存儲服務(wù)器茂嗓,文件和meta data都保存到存儲服務(wù)器上

?group:組餐茵,也可稱為卷。同組內(nèi)服務(wù)器上的文件是完全相同的

?文件標識:包括兩部分:組名和文件名(包含路徑)

?meta data:文件相關(guān)屬性述吸,鍵值對(Key Value Pair)方式忿族,如:width=1024,heigth=768

同步機制

?同一組內(nèi)的storageserver之間是對等的,文件上傳蝌矛、刪除等操作可以在任意一臺storage server上進行道批;

?文件同步只在同組內(nèi)的storage server之間進行,采用push方式入撒,即源服務(wù)器同步給目標服務(wù)器隆豹;

?源頭數(shù)據(jù)才需要同步,備份數(shù)據(jù)不需要再次同步茅逮,否則就構(gòu)成環(huán)路了璃赡;

?上述第二條規(guī)則有個例外判哥,就是新增加一臺storage server時,由已有的一臺storageserver將已有的所有數(shù)據(jù)(包括源頭數(shù)據(jù)和備份數(shù)據(jù))同步給該新增服務(wù)器碉考。

通信協(xié)議

?協(xié)議包由兩部分組成:header和body

?header共10字節(jié)塌计,格式如下:

–8 bytes body length

–1 byte command

–1 byte status

?body數(shù)據(jù)包格式由取決于具體的命令,body可以為空

運行時目錄結(jié)構(gòu)-tracker server

?${base_path}

|__data

|???? |__storage_groups.dat:存儲分組信息

|????|__storage_servers.dat:存儲服務(wù)器列表

|__logs

|__trackerd.log:trackerserver日志文件

運行時目錄結(jié)構(gòu)-storage server

?${base_path}

|__data

|???? |__.data_init_flag:當前storageserver初始化信息

|????|__storage_stat.dat:當前storage server統(tǒng)計信息

|????|__sync:存放數(shù)據(jù)同步相關(guān)文件

|????|???? |__binlog.index:當前的binlog文件索引號

|????|???? |__binlog.###:存放更新操作記錄(日志)

|????|???? |__${ip_addr}_${port}.mark:存放同步的完成情況

|????|

|???? |__一級目錄:256個存放數(shù)據(jù)文件的目錄侯谁,如:00, 1F

|?????????? |__二級目錄:256個存放數(shù)據(jù)文件的目錄

|__logs

|__storaged.log:storageserver日志文件

安裝和運行

?#step 1. download FastDFS source package and unpack it,

?# if you use HTTP to download file, please downloadlibevent 1.4.x and install it

?tar xzf FastDFS_v1.x.tar.gz

?#for example:

?tar xzf FastDFS_v1.20.tar.gz

?#step 2. enter the FastDFS dir

?cd FastDFS

?#step 3. if HTTP supported, modify make.sh, uncommentthe line:

?# WITH_HTTPD=1, then execute:

?./make.sh

?#step 4. make install

?./make.sh install

?#step 5. edit/modify the config file of tracker andstorage

?#step 6. run server programs

?#start the tracker server:

?/usr/local/bin/fdfs_trackerd

?#start the storage server:

?/usr/local/bin/fdfs_storaged

FastDFS和集中存儲方式對比

指標 ? ? ? ? ? ? ? ? ? ? ? ? ?FastDFS ? ? ? ? ? ? ? ? ? ? ? ? ?NFS ? ? ? ? ? ? ? ? ? ?集中存儲設(shè)備?如NetApp锌仅、NAS

線性擴容性 ? ? ? ? ? ? ? ? ? 高 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?差 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?差

文件高并發(fā)訪問性能 ? 高 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?差 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?一般

文件訪問方式 ? ? ? ? ? ? ? ?專有API ? ? ? ? ? ? ? ? ? ? ? ? ? ?POSIX ? ? ? ? ? ? ? ? ? ? ? ? ??支持POSIX

硬件成本 ? ? ? ? ? ? ? ? ? ? ? ? ?較低 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 中等 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??高

相同內(nèi)容文件只保存一份 ?支持 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 不支持 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?不支持

歡迎大家一起學習研究相關(guān)技術(shù),源碼來源:minglisoft.cn/technology

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末墙贱,一起剝皮案震驚了整個濱河市热芹,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌嫩痰,老刑警劉巖剿吻,帶你破解...
    沈念sama閱讀 219,366評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異串纺,居然都是意外死亡丽旅,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評論 3 395
  • 文/潘曉璐 我一進店門纺棺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來榄笙,“玉大人,你說我怎么就攤上這事祷蝌∶┳玻” “怎么了?”我有些...
    開封第一講書人閱讀 165,689評論 0 356
  • 文/不壞的土叔 我叫張陵巨朦,是天一觀的道長米丘。 經(jīng)常有香客問我,道長糊啡,這世上最難降的妖魔是什么拄查? 我笑而不...
    開封第一講書人閱讀 58,925評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮棚蓄,結(jié)果婚禮上堕扶,老公的妹妹穿的比我還像新娘。我一直安慰自己梭依,他們只是感情好稍算,可當我...
    茶點故事閱讀 67,942評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著役拴,像睡著了一般糊探。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,727評論 1 305
  • 那天侧到,我揣著相機與錄音勃教,去河邊找鬼。 笑死匠抗,一個胖子當著我的面吹牛故源,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播汞贸,決...
    沈念sama閱讀 40,447評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼绳军,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了矢腻?” 一聲冷哼從身側(cè)響起门驾,我...
    開封第一講書人閱讀 39,349評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎多柑,沒想到半個月后奶是,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,820評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡竣灌,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,990評論 3 337
  • 正文 我和宋清朗相戀三年聂沙,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片初嘹。...
    茶點故事閱讀 40,127評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡及汉,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出屯烦,到底是詐尸還是另有隱情坷随,我是刑警寧澤,帶...
    沈念sama閱讀 35,812評論 5 346
  • 正文 年R本政府宣布驻龟,位于F島的核電站温眉,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏翁狐。R本人自食惡果不足惜芍殖,卻給世界環(huán)境...
    茶點故事閱讀 41,471評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望谴蔑。 院中可真熱鬧,春花似錦龟梦、人聲如沸隐锭。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽钦睡。三九已至,卻和暖如春躁倒,著一層夾襖步出監(jiān)牢的瞬間荞怒,已是汗流浹背洒琢。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留褐桌,地道東北人衰抑。 一個月前我還...
    沈念sama閱讀 48,388評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像荧嵌,于是被迫代替她去往敵國和親呛踊。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,066評論 2 355

推薦閱讀更多精彩內(nèi)容