主页 > imtoken官网最新版 > 以太坊学习笔记(四)——以太坊私链多节点运行

以太坊学习笔记(四)——以太坊私链多节点运行

imtoken官网最新版 2023-03-19 05:11:36

本文主要是对上一篇文章的补充。 在进行之前,我们需要准备两台部署了以太坊环境的电脑。 建议学习以太坊或其他区块链项目首选Linux或mac os。 个人感觉cmd使用起来不是很方便,因为我另外一台电脑是window系统,所以在window上重新编译了以太坊源码以太坊节点搭建有什么用,在编译过程中遇到了一些问题,这里简单说一下解决方法顺便说一下问题。

编译源代码

1、准备Go语言环境,可以直接到官网下载安装包。 安装后一般会自动配置环境变量,但是需要配置$GOPATH环境变量,如果不知道怎么去网上找教程。

2. go-ethereum源码和golang.org\x\net源码(注意window下的路径分隔符),源码一定要放在$GOPATH\src下,文件结构如下:

$GOPATH$/src  
├── github.com  
│   └── ethereum  
│       └── go-ethereum  
└── golang.org  
 └── x  
     └── net 

3.配置GCC环境

如果没有配置gcc环境,编译过程中会报如下错误:

矿工自己搭建以太坊矿池教程_以太坊私有链搭建_以太坊节点搭建有什么用

exec: "gcc": executable file not found in %PATH%

解决方案:

下载并安装GCC,然后将安装目录下的bin文件夹添加到Path环境变量中,打开cmd,输入

gcc -v

如果出现版本信息,则安装成功。

提示:每次修改环境变量,都要重新打开cmd

继续编译源码,出现错误信息:

cc1.exe: sorry, unimplemented: 64-bit mode not compiled in

解决方案:

直接下载编译好的包进行安装

4.编译源码

以太坊私有链搭建_以太坊节点搭建有什么用_矿工自己搭建以太坊矿池教程

在cmd中切换到$GOPATH\src路径,然后执行命令:

go install -v github.com\ethereum\go-ethereum\cmd\geth
go install -v github.com\ethereum\go-ethereum\cmd\evm

编译成功后,geth.exe和evm.exe会出现在$GOPATH\bin中,如下图:

以太坊节点搭建有什么用_矿工自己搭建以太坊矿池教程_以太坊私有链搭建

准备创世块的步骤与上一章中提到的步骤相同。 注意genesis.json的内容和前面的完全一样。 文件结构如下:

以太坊节点搭建有什么用_矿工自己搭建以太坊矿池教程_以太坊私有链搭建

暗示:

可以根据个人喜好将文件放在其他地方以太坊节点搭建有什么用,初始化和启动节点时需要跟上完整路径

初始化创世块

geth --datadir d:\ethprivatechain\data init d:\ethprivatechain\genesis.json

起始节点

以太坊私有链搭建_矿工自己搭建以太坊矿池教程_以太坊节点搭建有什么用

1.进入geth控制台

geth --datadir d:\ethprivatechain\data --networkid 100 console

为了区分操作,我的两台电脑mac是节点1,win是节点2,在mac和win上启动geth

2.获取mac上节点的enode信息

> admin.nodeInfo.enode
//输出信息
"enode://e08f44fbedfd17b549a5237ebe7548501a891f34859cd71fdf083d99e8de2763902967af54f67423ac632648904674ffa86d7fa6fccee649a992b4942f424b17@[::]:30303"

3.在win的节点上添加第一个节点的操作

> admin.addPeer("enode://e08f44fbedfd17b549a5237ebe7548501a891f34859cd71fdf083d9
9e8de2763902967af54f67423ac632648904674ffa86d7fa6fccee649a992b4942f424b17@192.16
8.111.20:30303")
//输出信息

以太坊私有链搭建_矿工自己搭建以太坊矿池教程_以太坊节点搭建有什么用

true

注意:enode信息中的[::]替换为第一个节点的ip,问号和后面的部分不是必须的

4.查看连接的节点

//查看连接的节点数量,此处为1
> net.peerCount
1
// 查看连接的节点信息
> admin.peers
[{
    caps: ["eth/63"],
    id: "e08f44fbedfd17b549a5237ebe7548501a891f34859cd71fdf083d99e8de2763902967a
f54f67423ac632648904674ffa86d7fa6fccee649a992b4942f424b17",
    name: "Geth/v1.8.16-unstable/darwin-amd64/go1.10.2",

以太坊节点搭建有什么用_以太坊私有链搭建_矿工自己搭建以太坊矿池教程

network: { localAddress: "192.168.111.233:64651", remoteAddress: "192.168.111.20:30303" }, protocols: { eth: { difficulty: 17179869184, head: "0xd4e56740f876aef8c010b86a40d5f56745a118d0906a34e69aec8c0db1cb8fa 3", version: 63 } } }]

节点1和节点2都可以挖矿,只要有一个节点在挖矿,其他节点的交易也可以正常进行。