:2026-04-06 2:57 点击:4
在区块链技术的探索与应用中,私有链因其可控性、隐私性和高性能等特点,在企业级应用、内部审计、测试网络等场景中备受青睐,以太坊作为最智能合约平台的代表,其私有链的搭建为开发者提供了熟悉且强大的开发环境,本文将聚焦于以太坊私有链中最基础也最具代表性的配置——两个节点的部署,探讨其意义、搭建步骤及协同工作原理。
为何选择以太坊私有链双节点?
虽然单节点私有链最为简单,但双节点配置具有独特的价值和意义:
以太坊私有链双节点部署核心步骤
部署以太坊私有链双节点,通常可以采用以下两种主流方式,这里我们重点介绍更灵活、更常用的使用Geth(Go-Ethereum)客户端搭建的方法。
前提条件:
两台机器(或同一台机器上的两个不同端口,模拟双节点),已安装Go语言环境(Geth依赖),并配置好git。

详细步骤:
准备创世块配置文件 (genesis.json)
在任意一台机器(或两台机器的同一路径下)创建一个genesis.json如下(这是一个简单的PoA共识示例,使用clique算法,适合私有链):
{
"config": {
"chainId": 12345, // 私有链的链ID,确保与公有链不冲突
"homesteadBlock": 0,
"eip150Block": 0,
"eip155Block": 0,
"eip158Block": 0,
"byzantiumBlock": 0,
"constantinopleBlock": 0,
"petersburgBlock": 0,
"istanbulBlock": 0,
"berlinBlock": 0,
"londonBlock": 0,
"parisBlock": 0,
"mergeNetsplitBlock": 0,
"shanghaiTime": 0,
"cancunTime": 0,
"pragueTime": 0,
"verkleTime": 0,
"terminalTotalDifficulty": 0,
"terminalTotalDifficultyPassed": true,
"clique": { // PoA共识配置
"period": 15, // 出块时间(秒)
"epoch": 30000 // 每个epoch长度(区块数)
}
},
"nonce": "0x0",
"timestamp": "0x0",
"extraData": "0x0000000000000000000000000000000000000000000000000000000000000000", // 初始矿工地址可后续添加
"gasLimit": "0x8000000",
"difficulty": "0x400000",
"mixHash": "0x0000000000000000000000000000000000000000000000000000000000000000",
"coinbase": "0x0000000000000000000000000000000000000000",
"alloc": {} // 可预分配账户,这里留空
}
初始化创世块
在两台节点机器上,分别执行以下命令(假设genesis.json位于当前目录):
geth --datadir ./node1 init genesis.json geth --datadir ./node2 init genesis.json
此命令会在./node1和./node2目录下生成创世块数据。
启动第一个节点 (Node1)
在节点1机器上,启动Geth节点,并指定端口(如30303):
geth --datadir ./node1 --port 30303 --nodiscover --ipcdisable --http --http.addr "0.0.0.0" --http.port 8545 --http.api "personal,eth,net,web3,miner" --unlock 0 --password <(echo "your_password") --mine
参数说明:
--datadir ./node1:指定数据目录。--port 30303:设置P2P网络端口。--nodiscover:禁止节点自动发现,避免连接到其他网络。--ipcdisable:禁用IPC接口(可选,若需使用IPC可开启)。--http --http.addr "0.0.0.0" --http.port 8545 --http-api "...":启用HTTP-RPC服务,方便外部连接。--unlock 0 --password <(echo "your_password"):解锁第一个账户(初始化时会自动创建)用于挖矿。--mine:启动挖矿。启动第二个节点 (Node2)
在节点2机器上,同样启动Geth节点,但需使用不同的端口(如30304)和数据目录:
geth --datadir ./node2 --port 30304 --nodiscover --ipcdisable --http --http.addr "0.0.0.0" --http.port 8546 --http-api "personal,eth,net,web3,miner" --unlock 0 --password <(echo "your_password") --mine
注意这里的--port、--datadir和HTTP端口都与Node1不同。
连接两个节点
两个节点是独立运行的,尚未形成网络,需要手动将Node2添加到Node1的节点列表,或将Node1添加到Node2的节点列表。
在Node1机器上,打开另一个终端, attach到Node1的Geth控制台:
geth attach http://localhost:8545
在控制台中执行以下命令,添加Node2的enode地址(需要先获取Node2的enode):
// 首先获取Node2的enode地址(在Node2机器上执行 geth node enode://...@<node2_ip>:30304 后得到)
// 假设Node2的IP是192.168.1.100
admin.addPeer("enode://<node2_enode_info>@192.168.1.100:30304")
在启动Node2时,可以通过--bootnodes参数指定Node1的enode地址:
geth --datadir ./node2 --port 30304 --nodiscover --bootnodes "enode://<node1_enode_info>@<node1_ip>:30303" --ipcdisable --http --http.addr "0.0.0.0" --http.port 8546 --http-api "personal,eth,net,web3,miner" --unlock 0 --password <(echo "your_password") --mine
其中<node1_enode_info>可以通过在Node1上执行geth node获取。
验证节点连接与同步
eth.blockNumber,观察两个节点的区块高度是否一致并增长。admin.peers,查看是否已连接到对方节点。双节点私有链的协同与进阶
一旦两个节点成功连接并同步,它们就构成了一个简单的以太坊私有链网络。
clique PoA共识,两个节点都可以配置为矿工本文由用户投稿上传,若侵权请提供版权资料并联系删除!