主页 > 官网安卓版下载imtoken > 以太坊学习笔记(四)——以太坊私链多节点操作

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

官网安卓版下载imtoken 2023-01-17 10:16:04

以太坊学习笔记(四)——以太坊私链多节点操作古河不笑··659点击··开始浏览

这是一篇创建于 的文章,其中的信息可能已经发展或更改。

第一次站长亲自招募Gopher>>

本文主要是对上一篇文章的补充之一,操作前一个节点放多少个以太坊地址好,我们需要准备两台以太坊环境的电脑。建议学习以太坊或其他区块链项目,更喜欢linux或mac os。个人觉得cmd用起来不是很方便,因为我有另一台电脑是window系统的,所以在window上重新编译了以太坊源码。在编译过程中遇到了一些问题,顺便简单说说解决方法。

编译源代码

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

2.go-ethereum源码和golang.org\x\net源码(注意窗口下的路力分隔符),源码必须放在$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

解决方案:

p>

直接下载编译包安装

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.exe和evm.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上启动geth,依次win

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都可以挖矿,只要一个节点在挖矿,其他节点的交易也可以正常进行。

如有问题请加站长微信联系方式(非本文作者)

本文来自:简书