當用戶以守護進程模式啟動filecoin時,最終執行的命令位于
commands/daemon.go文件,它的
Run方法直接調用同文件中的
daemonRun函數進行處理。這個函數的處理如下:
調用getRepo,獲得本地倉庫repo.Repo接口對象。這個方法內部調用倉庫的OpenFSRepo函數,生成并初始化倉庫對象,它的流程如下:
根據倉庫路徑和版本,生成倉庫repo.FSRepo對象。
鎖定相關倉庫的repo.lock文件,并設置倉庫對象的lockfile屬性,從而確保同時只有一個全節點可以使用倉庫,以便維護倉庫的完整性。
調用倉庫對象的loadFromDisk方法,從磁盤上加載倉庫的各種數據,并同繼續完善倉庫對象。這個方法的流程如下:
調用倉庫對象的readVersion方法,從倉庫文件中讀取倉庫的版本號,并與倉庫對象自身的版本號進行比較。如果不匹配,則拋出錯誤。
調用倉庫對象的loadConfig方法,加載倉庫的配置文件config.json。
調用倉庫對象的openDatastore方法,加載倉庫的數據存儲文件。默認情況下,數據存儲類型為badgerds,所以加載的文件目錄為倉庫下的這個目錄。這個方法會生成倉庫存儲對象,并保存在倉庫對象的ds屬性。
調用倉庫對象的openKeystore方法,打開倉庫的keystore文件。這個方法會生成私鑰存儲對象,并保存在倉庫對象的keystore屬性。
基于Cardano的擴容協議Hydra發布Node v.8.1.2更新:金色財經報道,Cardano (ADA) 新推出的擴容協議Hydra開發團隊宣布發布Node v.8.1.2更新,Node 8.1.2是Cardano節點的次要版本,更新了Plutus解釋器。此外,核心團隊更新到了GHC 9.2.7,縮短了編譯時間以及Plutus 腳本構建。Cardano Hydra自推出以來已經集成了多項升級,以確保其能力和功能的順利交付。 根據設計,Hydra的目標是推動Cardano每秒處理多達數千筆交易(TPS)。[2023/7/29 16:05:44]
調用倉庫對象的openWalletDatastore方法,打開錢包數據存儲。這個方法會生成倉庫存儲對象,并保存在倉庫對象的walletDs屬性。這次對象對應的目錄為wallet。
調用倉庫對象的openChainDatastore方法,打開區塊鏈數據存儲。這個方法會生成倉庫存儲對象,并保存在倉庫對象的chainDs屬性。這次對象對應的目錄為chain。
調用倉庫對象的openDealsDatastore方法,打開交易數據存儲。
這個方法會生成倉庫存儲對象,并保存在倉庫對象的dealsDs屬性。這次對象對應的目錄為deals。
獲取環境變量。
獲取命令行參數。
調用節點的New方法,創建一個節點。首先,生成一個配置對象,使用前面幾步形成的選項參數和倉庫對象來設置配置對象;然后調用配置對象的Build方法,構建一個Filecoin節點。當我們不帶參數啟動時,配置對象中只有倉庫對象會被設置。Build函數執行流程如下:
數據:比特幣與美元三十天相關性系數今日為-0.05:金色財經報道,據同伴客數據顯示,6月26比特幣與跨資產類別價格相關性系數情況如下:
比特幣與標普500 三十天天相關系數為-0.07,一周累計下跌0.24。
比特幣和黃金三十天相關系數為0.03,一周累計下跌-0.11。
比特幣和美元三十天相關系數為-0.05,一周累計上漲0.07。
備注:
①\t相關性系數值為正,表示正相關;值為負則為負相關
②\t相關性系數值≤0.5表示低度相關;0.5~0.8表示顯著相關;≥0.8表示高度相關[2023/6/26 22:01:07]
如果配置對象中沒有倉庫對象,則生成一個內存版倉庫對象。
生成區塊存儲對象。?
'調用配置對象的buildHost方法,生成libp2pHost對象'。buildHost方法調用libp2p的New方法,這個方法最終調用config/config.go中定義的NewNode方法,這個方法:
首先,調用swarm的NewSwarm方法創建一個swarm對象。
然后,調用basic_host.go中定義的NewHost來創建host對象。在創建host對象過程中,把swarm對象保存為host對象的網絡對象,同時設置swarm的連接處理器和流處理器分別為host對象的newConnHandler和newStreamHandler兩個方法。
然后,調用swarm的AddTransport方法,添加指定的傳輸協義。
eToro完成2.5億美元融資:金色財經報道,在取消了在 2022 年以104 億美元的估值通過 SPAC 上市的計劃后,交易平臺 eToro 以 35 億美元的估值獲得了 2.5 億美元的融資。投資者包括 ION Group、Social Leverage、SoftBank 和 Spark Capital。
eToro 創始人兼首席執行官 Yoni Assia 表示,這筆資金不是典型的股權融資:它是通過高級投資協議 (AIA) 獲得的。該公司已于 2021 年初獲得友邦保險,作為當前支持者的一種支持,以防其擬議的 SPAC 失敗。[2023/3/21 13:17:40]
最后,調用host的Listen方法,開始監聽指定的地址。
生成pinger服務對象。
生成區塊驗證器consensus.DefaultBlockValidator對象。
使用libp2pHost對象和路由對象,生成bitswap網絡對象。
使用bitswap網絡對象和區塊存儲對象,生成bitswap對象。
使用區塊存儲對象和bitswap對象,生成區塊服務對象。
生成獲取區塊net.Fetcher對象,以便從遠程節點獲取數據。
''調用readGenesisCid函數,獲取創世區塊的CID''。
生成chain.Store對象。
生成chain.ChainStateProvider對象。
韓媒:Gopax創始人或已辭去首席執行官職務:2月12日消息,在本月初幣安收購韓國交易所Gopax部分股權后,Gopax創始人李俊行(音譯)辭去首席執行官職務。李俊行出售了其持有的全部Gopax 41.22%的股份。新任命的三名董事中的一位馬來西亞人被任命為Gopax新任首席執行官。不過,Gopax的一位負責人表示,我認為我們需要核實此辭職是否屬實。2月初,據彭博社報道,幣安已收購韓國交易所Gopax多數股權,此次收購的資金來自幣安此前推出的10億美元的“行業復蘇計劃”,具體收購條款未披露。[2023/2/12 12:02:21]
生成powerTable對象,類型為consensus.MarketView對象。
根據配置對象是否有獎勵,調用不同的方法節點共識器。如果獎勵對象為空,則調用consensus/processor.go的NewDefaultProcessor函數,生成共識器;否則,調用NewConfiguredProcessor函數,生成共識器。兩個函數都生成consensus.DefaultProcessor對象,區塊在于它們的屬性。
調用consensus/NewExpected.go的NewExpected函數,生成consensus.Protocol接口節點共識consensus.Expected對象。根據配置對象是否有proofs.Verifier接口對象,在生成過程中會使用不同的參數。
調用go-libp2p-pubsub類庫的NewFloodSub函數,生成一個發布/訂閱pubsub.PubSub對象fsub,監聽自身的所有消息。
Signature Bank設立數字資產存款上限,單個客戶存款不超過20億美元:12月8日消息,Signature Bank正在設置數字資產存款上限,以將數字資產行業客戶的存款占比降低到銀行存款總額的20%以下。
據悉,Signature Bank第三季度存款額為1020億美元,該措施將把整個數字生態系統的存款總額限制在204億美元。此外,Signature Bank董事Joseph Seibert在致客戶的一封電子郵件稱,將對每個客戶的存款上限設定為銀行存款總額的最高2%,并對TheBlock補充道,每個客戶存款不超過20億美元。(TheBlock)[2022/12/8 21:30:51]
使用倉庫repo.Repo接口對象的walletDs屬性作為錢包后端,生成錢包wallet.Wallet對象。
調用chain/syncer.go的NewSyncer函數,生成區塊鏈chain.Syncer同步對象。
生成core.MessagePool對象。
生成core.Inbox對象。
生成core.MessageQueue對象。
生成node.defaultMessagePublisher對象。消息發布對象綁定的主題為/fil/msgs/devnet-3,它會在這個主題上發布消息。在全節點的啟動方法中通過,通過調用porcelain.API對象的PubSubSubscribe方法,訂閱這個主題的消息通知。
生成core.Outbox對象。這個對象上一步創建的消息發布對象,當調用porcelain.API對象的MessageSend方法發送消息時,內部調用本對象的Send方法,進行發送。發送方法最終調用消息發布對象的Publish,把經過簽名之后的消息發布到相應的主題上。當消息發送之后,別的全節點對象因為訂閱了消息主題,所以會調用全節點的processMessage的方法進行處理。具體見全節點啟動過程。
'生成PorcelainAPI對象。
'生成Filecoinnode.Node全節點對象。
'生成net.Bootstrapper引導對象。
返回Filecoin全節點對象。
調用內部函數runAPIAndWait,啟動全節點。
''調用節點的Start方法,啟動Filecon節點''。
調用chain.Store對象的Load方法,加載本地已有區塊。
調用全節點對象的miningAddress方法,獲取礦工地址;如果配置了礦工地址,則調用node.Node全節點對象的setupMining方法,設置挖礦。這個方法調用initSectorBuilderForNode函數,初始化初始化扇區生成器,并保存在全節點對象的sectorBuilder屬性上。
生成syncCallBack同步回調函數對象,用于處理區塊同步。
調用protocol/hello/hello.go文件的New函數,進行Hello消息處理設置這個方法內部處理如下:
生成一個hello協義處理器對象,并設置為全節點對象的HelloSvc屬性。
設置libp2p/fil/hello/1.0.0協義處理器為protocol.hello.Handler對象的handleNewStream方法。
設置libp2p網絡對象的連接通知為protocol.hello.helloNotify對象。
調用Filecoin節點的setupProtocols方法,設置各種協義。這個方法內部處理如下:
生成protocol.block.MiningAPI對象,并保存為全節點對象的BlockMiningAPI屬性。
調用protocol/retrieval/api.go文件的NewAPI函數,生成protocol.retrieval.API對象,并促為全節點對象的RetrievalAPI屬性。
調用protocol/storage/api.go文件的NewAPI函數,生成protocol.storage.API對象,并促為全節點對象的StorageAPI屬性。
以全節點對象為參數,調用protocol/retrieval/NewMiner.go的NewMiner函數,生成一個檢索礦工,并為設置全節點對象的RetrievalMiner屬性。這個函數首先生成一個檢索礦工,然后調用全節點對象的libp2pHost對象的SetStreamHandler方法,設置/fil/retrieval/free/0.0.0協議的處理器為檢索礦工的handleRetrievePieceForFree方法,最后返回檢索礦工。
調用porcelain.API對象的PubSubSubscribe方法,訂閱/fil/blocks/devnet-3主題的區塊通知,并設置為全節點的BlockSub屬性。?
調用porcelain.API對象的PubSubSubscribe方法,訂閱/fil/msgs/devnet-3主題的消息通知,并設置為全節點的MessageSub屬性。
啟動一個協程,在協程中調用全節點的handleSubscription方法,處理區塊通知。這個方法主體是一個無限循環。它從參數指定的主題中讀取主題,并調用參數指定的方法進行處理。區塊通知訂閱的是/fil/blocks/devnet-3,它的處理方法是全節點的processBlock方法。
啟動一個協程,在協程中調用全節點的handleSubscription方法,處理消息通知。消息通知訂閱的是/fil/msgs/devnet-3,它的處理方法是全節點的processMessage方法。這個方法把收到的消息進行反序列化,然后調用core.Inbox對象的Add方法,把消息對象保存在core.MessagePool對象中。
調用chain.Store對象的HeadEvents方法,使用其返回的發布/訂閱對象的Sub方法,訂閱新區塊頭部主題new-head。
調用porcelain.API對象的ChainHead方法,返回處理區塊鏈頭部的函數,在一個協程中調用全節點的handleNewHeaviestTipSet方法,處理區塊鏈頭部消息。
非離線模式下,啟動net.Bootstrapper引導對象。引導對象會連接到所有的引導節點,并在連接成功后,調用protocol.hello.helloNotify對象的Connected方法,從而向遠程節點發送自身的頂層區塊信息,而遠程節點也會向我們發送它的頂層區塊信息,從而開啟區塊同步過程。
設置心跳服務。
生成命令行環境commands.Env對象。
生成服務器配置變量
生成GoServeMux處理器對象,設置它處理/debug/pprof/請求的對象為Go自身的DefaultServeMux;處理/api/請求的go-ipfs-cmds類庫的handler對象。handler對象持有上面生成的環境變量、服務器配置變量等。
創建Http服務器。
在一個單獨線程中啟動Http服務器。
Tags:PRONEWTORAPIInverse Protocolnew牛頓幣價格torn幣價格FinShi Capital
本文作者:CoboVault安全練習生2019年9月,網絡安全公司AdaptiveMobile發現了SIM卡存在一個嚴重的漏洞「Simjacker」.
1900/1/1 0:00:00昨天,一則關于EOS的消息在社區里炸開了鍋:EOSNewYork稱,有6個EOS節點被同一節點所控制,即目前排名第52位的EOShenzhen節點.
1900/1/1 0:00:00來源:小蔥區塊鏈 德意志銀行報告《暢想2030》表示,隨著通脹加劇,人們對政府支持的貨幣的可持續性越來越懷疑,這可能會促使更多的人購買數字資產。報告對未來10年的24種替代方案進行了分析.
1900/1/1 0:00:00寫在前面:本文為加密貨幣交易所Gemini創始人之一TylerWinklevoss在問答網站Quora上的回復.
1900/1/1 0:00:00據Bitcoinist12月2日報道,日本電信運營商軟銀與美國的錢包卡開發商Dynamics合作,推出了內置區塊鏈錢包的SBC錢包卡.
1900/1/1 0:00:00編譯:聽風 來源:白話區塊鏈 巴西阿雷格里港的兩個女孩Caroline和Kaká啟動了一個名為“靠加密貨幣生活”的項目,開啟了一段只使用加密貨幣付款的挑戰之旅.
1900/1/1 0:00:00