本文是《循序漸進比特幣》第三篇祟峦。為什么要講解啟動過程呢罚斗?只有找到了程序入口,學(xué)會調(diào)試宅楞,開始嘗試著閱讀源碼针姿,才能更好地了解系統(tǒng)運行原理袱吆。btcd啟動的源碼位于這兒。
btcd 啟動主要分了三步:
- 加載配置
- 新建server
- server啟動距淫。
其他步驟(比如啟動關(guān)閉監(jiān)聽routine绞绒、cpu profile等)不是核心流程,我們暫時忽略榕暇。如果感興趣蓬衡,可以自己閱讀源碼哦~
下面我們來分析一下每一步的主要流程。
1 加載配置
加載配置的代碼位置: loadConfig 函數(shù)
流程圖如下:
loadConfig
其中彤枢,如下幾點需要關(guān)注一下狰晚,在以后的文章中,可能會用到這些點缴啡,或者重點展開講解這西點壁晒。
- Listener 配置:是指節(jié)點的ip、port, 如果不配置业栅,會讀取默認(rèn)值秒咐。
- rpc Server: 只有配置了rpc相關(guān)的設(shè)置,才會啟動rpc server式镐。
- addPeer: 是指啟動時鏈接特定的peer反镇。 如果指定了,則使用這些peer信息娘汞; 如果沒有指定歹茶,在mainnet的場景下,會使用DNSSeed中指定的peer你弦。
- minrelaytxfee: 設(shè)定了交易手續(xù)費的最低金額惊豺,如果低于這個金額,則交易很難被打包禽作。
- BlockMaxSize: 設(shè)定了區(qū)塊的大小尸昧,這也限制了每個區(qū)塊最大能夠打包的交易數(shù)目。默認(rèn)1M
2 新建server
newServer代碼地址
newServer的主要流程如下:
newServer
其中有幾個點需要解釋一下:
- addrManager: 是地址管理器旷偿,可以理解是比特幣中address的管理器
- initListeners: 配置net listeners烹俗。
- checkPoint檢查: 是用來檢查歷史區(qū)塊中,某些高度上比特幣區(qū)塊的正確性的萍程,進而保證區(qū)塊同步的準(zhǔn)確性幢妄。如果你要使用比特幣的源碼創(chuàng)建自己的山寨幣,checkPoint需要設(shè)置為空茫负。
- feeEstimator: 目前還沒看到什么用途蕉鸳,等到后續(xù)用到時,再分析。如果你知道潮尝,可以留言告訴我哈榕吼,不勝感激~
- syncManager創(chuàng)建: 這一步除了新建了一個同步管理器,而且還監(jiān)聽了鏈相關(guān)的通知消息勉失,主要是NTBlockAccepted羹蚣、NTBlockConnected、NTBlockDisconnected消息戴质。 相關(guān)代碼地址度宦。
- rpcListener server創(chuàng)建: 除了創(chuàng)建了rpcServer, 而且新建了websocket 消息管理器,訂閱了鏈相關(guān)的通知告匠。同syncManager創(chuàng)建的消息類型一樣戈抄。
3 啟動server
server.Start代碼地址
流程圖如下:
server.Start
看流程圖就幾步,其實內(nèi)部不少。有幾個注意點:
- s.peerHandler: 很重要,里面有地址管理器尽棕、數(shù)據(jù)同步管理器、鏈接管理器的啟動裸诽。
(1)地址管理器啟動時,定義了一個addressHandler的routine型凳, 主要的作用是記錄address丈冬,方便下次重啟時可以直接讀取 。
(2)數(shù)據(jù)同步管理器則定義了一個blockHandler的routine甘畅,雖然叫blockHandler,實際會處理區(qū)塊埂蕊、消息、peer疏唾、庫存等多種消息蓄氧。感興趣,自己看源碼吧~槐脏。
(3)鏈接管理器則對于”進來的peer請求(inbound)“喉童、"要出去請求其他peer(outbound)"的操作分開了。其中定義了connHandler處理所有”進來的peer請求“顿天,并且啟動listenHandler 來處理即將建立鏈接的請求堂氯; 對于要鏈接其他peer的(outbound),則創(chuàng)建newConnReq. 這部分還涉及到了DNSSeed的問題牌废,如果是主網(wǎng)而且沒有指定鏈接哪個peer去同步數(shù)據(jù)咽白,則默認(rèn)使用DNSSeed列表中的peer。 如果你想創(chuàng)建自己的山寨幣畔规,這兒地方可以改成自己的peer地址信息哦~- rebroadcastHandler: 跟蹤用戶已經(jīng)提交并發(fā)送,但是還沒有被寫入?yún)^(qū)塊的庫存信息恨统。
- rpcServer.start:分了http請求跟web socket請求兩種叁扫。
- cpuMiner.start: 核心的邏輯在miningWorkerController , 后續(xù)會有專門的文章分析挖礦邏輯三妈。這兒不展開了。
4 總結(jié)
本文結(jié)合比特幣源碼莫绣,分析了btcd啟動過程畴蒲。從加載配置、服務(wù)定義对室、服務(wù)啟動三個方面進行了講解模燥。雖然這篇是源碼分析,但是文中并沒有貼代碼片段掩宜,而是放了鏈接蔫骂。如果對實現(xiàn)細(xì)節(jié)感興趣,可以根據(jù)鏈接牺汤,自己去探究辽旋。如果遇到問題,歡迎留言檐迟,我們一起討論补胚,提高。
5 參考文獻(xiàn)
6 其他
本文是《循序漸進比特幣》的第三篇-《btcd版比特幣節(jié)點-啟動過程源碼分析》追迟。
如果有疑問溶其,可以直接留言,也可以關(guān)注公眾號 “鏈人成長chainerup” 提問留言敦间,或者加入知識星球“鏈人成長”~