Filecoin的存儲單元稱為扇區。對傳統硬盤結構理解的小伙伴,對這個術語應該比較親切,傳統硬盤的最小存儲單元就叫Sector。為了證明Sector的存儲,Filecoin進行了一系列的處理,傳說中的P1/P2/C1/C2。在處理過程中,一個Sector的計算會生成若干文件,最終會生成replica。相關文件是如何組織的?Cache都是由哪些文件組成,分別是多大?本文就從存儲的角度看看這些過程和邏輯。
Filecoin的存儲管理的邏輯主要實現在sector-storage項目中。在深入理解Sector存儲邏輯之前,先講講Worker和Manager。
01?相關術語
Worker-處理P1/P2/C1/C2的服務,Worker又分為兩種:localworker和remoteworker。localworker處理本地服務處理,remoteworker支持遠程服務處理
Axie Infinity推出“Body Color Filter”新功能:金色財經報道,Axie Infinity在社交媒體宣布最新推出的角色主體顏色過濾器“Body Color Filter”新功能已經在app.axie上線,該功能允許玩家更改 Axies 身體的顏色,增強了用戶自定義權限,幾個月前由 Big Yak Axie Club (BYAC) 社區投票命名。[2023/3/3 12:39:41]
Manager-管理多個Worker
Scheduler-調度器,調度多個Worker,一個Manager通常有一個Scheduler
Store-Sector存儲系統
02?Sector存儲
Sector處理相關的文件存儲在Store中。Store通過sectorstore.json進行配置:
Filecoin網絡近24小時產出33.91萬枚FIL:據IPFS100報道,Filfox瀏覽器數據顯示,Filecoin網絡當前區塊高度為1121402,全網有效算力為11.024EiB,總質押量約為1.1159億枚FIL,活躍礦工數為3241個,每區塊獎勵為23.9280FIL,近24小時產出339117枚FIL,24小時平均挖礦收益為0.0296FIL/TiB,目前FIL流通量為171891182。當前銷毀28052768枚FIL。當前FIL最新價格為86.58美元。
目前有效算力排名前三的分別為:f0688165(MetaverseInfrastructure)以142.21PiB位居第一,f0127595(MetaverseInfrast)以132.70PiB暫居第二,f0142720(RRM-雅典娜)以124.10PiB位居第三。
注:根據Filecoin官方釋放規則,Filecoin將于2021年10月15號迎來第二次減產。[2021/9/18 23:34:53]
CanSeal表明Store可以用來Seal,CanStore表面Store可以持久存儲Seal的結果(replica)。Weight是權重,在多個Store選擇時使用。ID是Store的UUID編號。
FilDA DAO FIP -005號提案調整FilDA挖礦激勵比例通過:據 FilDA 官方網站 顯示,FilDA DAO 投票決定FilDA挖礦激勵比例調整提案通過,FilDA 核心開發團隊將于GMT 4月14日 約20點(北京時間4月15日約02:00)開始正式調整,首次將一次性減少LP挖礦部分15%的份額,并增加借貸挖礦部分15%的份額,后續將跟進市場情況完成相關調整。
此項DAO 提案對FIlDA 聚焦借貸核心業務有重要意義,借貸總量規模將進一步擴大并提升FilDA 在借貸核心業務的競爭力。[2021/4/14 20:18:04]
一個Store中存在三種存儲,分別對應三種目錄:unsealed(未封存的文件),cache,sealed。
03?Worker&Store
sector-storage項目的README中的這張圖很好的解釋了sectorstorage的各個模塊以及相互的關系:
FIL跌破210美元關口 日內跌幅為8.83%:火幣全球站數據顯示,FIL短線下跌,跌破210美元關口,現報209.99美元,日內跌幅達到8.83%,行情波動較大,請做好風險控制。[2021/4/2 19:38:44]
整幅圖分為上下兩個部分:上部分是Manager,下部分是RemoteWorker。Manager中包括一個LocalWorker。stores.Index是所有Sector存儲的索引。Scheduler,上部分的中間,管理所有的Worker,并且調度Sector相關的存儲。
workermanagementAPIs通過/rpc/v0的jsonRPC接口實現remoteworker的管理。通過/remote的HTTPAPI實現存儲的Fetch操作,簡單的說,傳輸文件。specs-storage.Prover/Sealer/Storage是Manager暴露出來的接口,實現Sector的證明,封存和存儲。
FIL突破90美元關口 日內漲幅為7.4%:火幣全球站數據顯示,FIL短線上漲,突破90美元關口,現報90.0037美元,日內漲幅達到7.4%,行情波動較大,請做好風險控制。[2021/3/24 19:14:29]
每個連接到Manager的Worker會和Manager同步它的內存/CPU以及顯存的信息。Scheduler在接受到新的請求時,會針對請求(Task)的類型以及資源的需求,從當前Worker中挑選最合適的Worker進行請求的處理。如何選擇Worker,感興趣的小伙伴,可以查看selector的相關邏輯。
從存儲的角度,重新整理一下,這些關系:
以一個Manager連接兩個Worker為例。Worker只能Seal,但是不能Store。為了更清楚展示Worker之間的數據傳輸,第一個Worker只做Precommit1,第二個Worker做Precommit2和Commit。
04?SealTask
理解SealTask,最好對照了Sector的狀態管理一起看。對Sector狀態管理還不熟悉的小伙伴,可以查看之前的文章:
Filecoin-Sector狀態管理邏輯
接下來,看看每個SealTask對應的存儲數據的變化。
AddPiece
如果其中左邊的Worker接收到任務,AddPiece任務會在unsealed目錄中創建原始數據。
PreCommit1
PreCommit1階段,簡稱P1,針對SDR算法,計算若干層數據。如果Sector是32G,需要計算11層。對SDR算法不熟悉的小伙伴,可以看看之前的文章:
經過PreCommit1,生成的數據存儲在Cache中:
PreCommit2
PreCommit2的階段,簡稱P2,生成Replica,計算ColumnHash,并生成Merkle樹(tree_d,tree_c,tree_r_last)。因為P2,不在同一個Worker處理,在進行處理之前,需要先傳輸給合適的Worker,處理的結果同樣存儲在Cache中:
Commit和Finalize
在Commit生成證明后,進入Finalize狀態,Finalize可以理解成“歸檔”。因為在Worker上沒有Store能力,刪除不需要持久化的數據,需要持久化存儲的數據,將傳輸回Manager。
05?數據存儲量
以32G的Sector為例,在處理過程中需要存儲的數據如下:
原始數據-32G
原始數據Merkle-32G
P1layer-32*11G
P2-ColumnHash?&tree_c-32*2G
P2-Replica&tree_r_last-32G9.2M*8
總共:512G多一點。
06?持久化數據
Sector經過P1/P2/C1/C2處理后,也就是說,經過PoREP處理后,需要持久化存儲Replica的數據和tree_r_last的數據。tree_r_last的數據需要存儲的原因是PoSt要用到。特別注意的是,tree_r_last的數據并不是完整的Merkle樹數據,刪除了其中一些層的數據。
32G的Sector,對應的tree_r_last分成了8棵子樹,每棵子樹是8叉樹,默認存儲的時候,忽略了最低的兩層。也就是,去除最低兩層的存儲量為:
所以每棵子樹的存儲數據為4G*0.00223=9.13M。
也就是說,Sector持久化存儲比例在1.0022左右。
總結:
Filecoin存儲管理的邏輯主要在sector-storage中。Sector的處理任務,可以通過多個Worker完成。每個Worker的存儲目錄結構一致,Sector數據可以在多個Worker之間通過Http服務傳輸。Sector處理過程中,最大的存儲需求量在512G左右。持久化存儲比例為1.0022。
推特首席執行官JackDorsey擁有的交易應用CashApp的二季度比特幣交易收入達到8.75億美元.
1900/1/1 0:00:00Filecoin作為已經開發3年多的明星項目,在全球都有良好的社群基礎,基于Filecoin激勵層的IPFS技術也已經有很多應用落地,我們相信主網上線后FIL的幣價表現不會讓人失望.
1900/1/1 0:00:00尊敬的LBank用戶: LBank將于2020年8月11日16:00上線LID,具體如下:開啟交易對:LID/ETHLBank Labs宣布投資加密投資決策平臺LunarCrush:據官方消息.
1900/1/1 0:00:00主打「鏈上聚合收益」功能的DeFi協議Yearn.Finance推出不到一個月,就遭遇了輪番「分叉」,市場上接連出現了YFII、YFFI和YYFI三個主要「分叉」協議幣.
1900/1/1 0:00:00尊敬的用戶: 為慶祝社區合伙人3.0支持WPT進行鎖倉認購:https://wbfex.zendesk.
1900/1/1 0:00:00尊敬的用戶: WBF將于2020年8月6日19:00在開放區上線ST/USDT交易對。充值、提幣業務開放時間待定,將以公告形式另行通知.
1900/1/1 0:00:00