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

311 阅读3分钟

这篇文章主要是对上一篇文章的一个补充,在进行操作前,我们需要准备两台部署有以太坊环境的电脑。建议学习以太坊或是其它区块链项目首选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

编译成功之后在$GOPATH\bin会出现geth.exeevm.exe,如下图所示:

准备创世区块

这步操作跟上章讲的步骤一样,注意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都可以进行挖矿,并且只要有一个节点在进行挖矿,其他节点的交易也都能正常进行。