區塊鏈
挖礦,比特幣,EOS,以太坊

區塊鏈開發教程 區塊鏈教程 區塊鏈入門教程以太坊源碼分析node包建立多重協議eth節點

node包建立多重協議eth節點

node包建立多重協議以太坊節點

一個node是一組服務,通過共享資源提供RPC API。
Services提供devp2p協議,當node實例開始運行,服務被wire到devp2p網絡

Node管理資源

Node實例使用到的所有文件系統資源被放到data目錄中。
每個資源的路徑可以通過額外的node配置改寫。
data目錄是可選的。==如果沒有設置或資源路徑沒有指定,node包會在內存中創建資源。==

配置Node并開啟p2p服務,來訪問devp2p網絡。
每個devp2p網絡上的host有一個唯一標識符,node key.
在重啟過程中,Node實例維持這個key。
Node加載static的和trusted可信的節點列表,保證關于其他hosts的知識持久化。

JSON-RPC服務器可以在Node上啟動,上面運行著HTTP,WebSocket,IPC。
已注冊服務提供的RPC模塊,將通過通過這些endpoints提供。
用戶可以限制任何endpoint為RPC模塊的子集。
Node自身提供debug,admin,web3模塊。

通過service context,服務實現可以打開LevelDB數據庫。
node包選擇每個數據庫的文件系統位置。
如果node配置為沒有data目錄運行,databases替換為內存打開。

Node創建共享的加密的以太坊賬戶keys的store,Services能夠通過service context
訪問account manager

在實例之間共享數據目錄

如果Multiple node有區別的實例名稱,他們能夠共享一個數據目錄。
共享行為依賴于資源的類型。

devp2p相關資源(node key,static/trusted node列表,known hosts database)存儲到與實例名相同的目錄中。

LevelDB數據庫也存儲到實例子目錄中。
如果多節點實例使用同一data目錄,使用唯一名稱打開數據庫將為每一個實例創建一個數據庫。

賬戶key store在所有node之間共享,使用一個data目錄。
其location可以通過KeyStoreDir配置項修改。

Data Directory Sharing Example見doc.go

本包主要class結構

配置類代表配置項集合,用于微調P2P協議棧的網絡層。這些值能被所有注冊服務進一步擴展
Config
|-DataDir 文件系統目錄,node可將其用于任何數據存儲需求。
|-P2P P2P網絡的配置
|-KeyStoreDir 不指定,New會創建臨時目錄,node停止時銷毀
|-IPCPath IPC存放IPC endpoint的請求路徑。空路徑disable IPC
|-HTTPHost Host interface,在其上開啟HTTP RPC服務。
|-HTTPPort HTTP RPC服務使用的TCP端口號
|-HTTPModules 通過HTTP RCP接口暴露的API模塊列表
|-StaticNodes() 解析static-nodes.json文件,返回配置的靜態節點enode URLs列表
|-TrustedNodes() 解析trusted-nodes.json文件,返回配置的靜態節點enode URLs列表
|-NodeDB() returns the path to the discovery node database
|-NodeKey() 檢索當前節點配置的私鑰,先檢查手動設置key,失敗再查配置data目錄,都沒有,新生成。

Node
|-eventmux Event multiplexer used between the services of a stack
|-config
|-accman Manager is an overarching account manager that can communicate with various backends for signing transactions
|-instanceDirLock prevents concurrent use of instance directory
|-serverConfig p2p配置
|-server Server manages all peer connections
|-serviceFuncs ServiceConstructor is the function signature of the constructors
|-services Currently running services
|-rpcAPIs List of APIs currently provided by the node
|-inprocHandler In-process RPC request handler to process the API requests
|-ipc\\http\\ws屬性

備注:
1、Server represents a RPC server
2、// API describes the set of methods offered over the RPC interface
type API struct {
Namespace string // namespace under which the rpc methods of Service are exposed
Version string // api version for DApp\’s
Service interface{} // receiver instance which holds the methods
Public bool // indication if the methods must be considered safe for public use
}

Service
|-Protocols() Protocols retrieves the P2P protocols the service wishes to start.
|-APIs() APIs retrieves the list of RPC descriptors the service provides
|-Start(server *p2p.Server)
|-Stop()

ServiceContext
|-config
|-services Index of the already constructed services
|-EventMux Event multiplexer used for decoupled notifications
|-AccountManager Account manager created by the node.
|-OpenDatabase() 打開指定數據庫,通過node data目錄。如果是臨時節點,返回內存數據庫
|-Service() 檢索指定類型的運行服務

PrivateAdminAPI
|-AddPeer()
// Try to add the url as a static peer and return
node, err := discover.ParseNode(url)
|-RemovePeer() RemovePeer disconnects from a a remote node if the connection exists
|-PeerEvents()

PublicAdminAPI

贊(0)

評論 搶沙發

  • 昵稱 (必填)
  • 郵箱 (必填)
  • 網址
p3试机号99