使用Geth搭建以太坊私有链网络

什么是Geth

Geth是 ethereum 协议的Go语言实现,Geth支持ethereum中的各种操作;并且得益于Go语言的多平台特性,Geth也支持在多个平台上使用。

安装Geth

安装分为两种:

  1. 直接下载编译好的Geth二进制文件
  2. 从源码编译生成二进制文件

在本示例中,不需要对Geth代码进行修改,所以选择下载编译好的Geth二进制文件

在MacOS上安装

在terminal中执行

brew tap ethereum/ethereum
brew install ethereum

在Ubuntu上安装

在terminal中执行

sudo apt-get install software-properties-common
sudo add-apt-repository -y ppa:ethereum/ethereum
sudo apt-get update
sudo apt-get install ethereum

验证安装成功

在terminal中执行

geth version

出现如下显示,即为安装成功

Geth
Version: 1.7.3-stable
Architecture: amd64
Protocol Versions: [63 62]
Network Id: 1
Go Version: go1.9.3
Operating System: darwin
GOPATH=/Users/lamo/go/default
GOROOT=/Users/lamo/.gvm/gos/go1.8

创世块

任何以太链都以一个创世块开始,为此我们需要定义一些创世块的参数,以便更好的服务于我们的开发和测试。

以下是一个创世块的样例配置,该配置是json格式的:

{
  "config": {
        "chainId": 11
    },
  "alloc"      : {},
  "coinbase"   : "0x0000000000000000000000000000000000000000",
  "difficulty" : "0x20000",
  "extraData"  : "",
  "gasLimit"   : "0x2fefd8",
  "nonce"      : "0x0000000000000042",
  "mixhash"    : "0x0000000000000000000000000000000000000000000000000000000000000000",
  "parentHash" : "0x0000000000000000000000000000000000000000000000000000000000000000",
  "timestamp"  : "0x00"
}
  • config.chainId // 以太链的ID,用来唯一标记一条以太链

  • coinbase // 矿工账号,第一个区块挖出后将给这个矿工账号发送奖励

  • difficulty // 难度值,越大越难

  • extraData // 附加信息随便填

  • gasLimit // gas 的消耗总量限制,用来限制区块能包含的交易信息总和,因为我们是私有链,所以填最大

  • nonce // 一个 64 位随机数

  • mixhash // 与 nonce 配合用于挖矿,由上一个区块的一部分生成的 hash

  • parentHash // 上一个区块的 hash 值

  • alloc // 预设账号以及账号的以太币数量,这里不做配置

初始化以太链

在定义了一个创世块的配置文件之后,使用该创世块的配置文件初始化以太链;

geth --datadir "~/geth/nodes/node_1" init genesis.json

出现如下显示

WARN [02-11|17:49:04] No etherbase set and no accounts found as default 
INFO [02-11|17:49:04] Allocated cache and file handles         database=/Users/lamo/geth/node_1/geth/chaindata cache=16 handles=16
INFO [02-11|17:49:04] Writing custom genesis block 
INFO [02-11|17:49:04] Successfully wrote genesis state         database=chaindata                              hash=7d416a…b75a26
INFO [02-11|17:49:04] Allocated cache and file handles         database=/Users/lamo/geth/node_1/geth/lightchaindata cache=16 handles=16
INFO [02-11|17:49:04] Writing custom genesis block 
INFO [02-11|17:49:04] Successfully wrote genesis state         database=lightchaindata                              hash=7d416a…b75a26

初始化完成之后,启动geth进入交互式命令行工具

geth --datadir "~/geth/nodes/node_1" \
 --networkid 11 \
console 2> ~/geth/logs/console.log

查看节点信息

> admin.nodeInfo
{
  enode: "enode://860d8e7e94dfdc72c0c3ca8f5aa919f1a32cf3a2461a74eb0c1b0f8b3563b757b1e0c9cd53068e79774da3ec0d652acbfddeb75420b670fe9b208313293600af@[::]:30303",
  id: "860d8e7e94dfdc72c0c3ca8f5aa919f1a32cf3a2461a74eb0c1b0f8b3563b757b1e0c9cd53068e79774da3ec0d652acbfddeb75420b670fe9b208313293600af",
  ip: "::",
  listenAddr: "[::]:30303",
  name: "Geth/v1.7.3-stable/darwin-amd64/go1.9.3",
  ports: {
    discovery: 30303,
    listener: 30303
  },
  protocols: {
    eth: {
      difficulty: 65536,
      genesis: "0x7d416a4ed27810d9154d9407a9b2b8ea4094fe8c5ce1d87e50bf6016d6b75a26",
      head: "0x7d416a4ed27810d9154d9407a9b2b8ea4094fe8c5ce1d87e50bf6016d6b75a26",
      network: 11
    }
  }
}

此时,我们已经成功创建了一个只有一个创世块、只有一个节点的以太坊的私有链,但是这个以太链中还没有账户以及交易,下面我们来创建账户。

创建账户

在交互式命令行中运行

> personal.newAccount('geth')
"0xb6e09535504452d5f1be75b510944fa5942efb08"

创建了一个名为0xb6e09535504452d5f1be75b510944fa5942efb08,密码为geth的账户

通过以下命令确认这一点

> personal.listAccounts
["0xb6e09535504452d5f1be75b510944fa5942efb08"]

增加一个节点

打开一个新的terminal,使用刚才的创世块配置文件,初始化一个节点并启动

geth --datadir "~/geth/nodes/node_2" init genesis.json

geth --datadir "~/geth/nodes/node_2" \
 --networkid 11 \
 --port 30304 \
console 2> ~/geth/logs/console2.log

这是第二个节点的信息

> admin.nodeInfo
{
  enode: "enode://a94ece1f720ba0c5a83f52ac7915bb495c83f3b0a6f8691eb7e97f61c6f9c1c7becb6c6d4af7410ec634cd2ef35a5ea3d2ed8f0eab81cd7d7a559f9eb416893c@[::]:30304",
  id: "a94ece1f720ba0c5a83f52ac7915bb495c83f3b0a6f8691eb7e97f61c6f9c1c7becb6c6d4af7410ec634cd2ef35a5ea3d2ed8f0eab81cd7d7a559f9eb416893c",
  ip: "::",
  listenAddr: "[::]:30304",
  name: "Geth/v1.7.3-stable/darwin-amd64/go1.9.3",
  ports: {
    discovery: 30304,
    listener: 30304
  },
  protocols: {
    eth: {
      difficulty: 65536,
      genesis: "0x7d416a4ed27810d9154d9407a9b2b8ea4094fe8c5ce1d87e50bf6016d6b75a26",
      head: "0x7d416a4ed27810d9154d9407a9b2b8ea4094fe8c5ce1d87e50bf6016d6b75a26",
      network: 11
    }
  }
}

连接两个节点

以上操作仅仅创建了两个隔离的节点

在第二个节点上执行

> admin.peers
[]

发现都是空的,现在要把两个节点连接起来,在第二个节点上执行

admin.addPeer("enode://860d8e7e94dfdc72c0c3ca8f5aa919f1a32cf3a2461a74eb0c1b0f8b3563b757b1e0c9cd53068e79774da3ec0d652acbfddeb75420b670fe9b208313293600af@[::]:30303")

其中admin.addPeer("enode://860d8e7e94dfdc72c0c3ca8f5aa919f1a32cf3a2461a74eb0c1b0f8b3563b757b1e0c9cd53068e79774da3ec0d652acbfddeb75420b670fe9b208313293600af@[::]:30303")这一串地址是节点1的信息。

此时就可以看到

> admin.peers

[{
    caps: ["eth/63"],
    id: "860d8e7e94dfdc72c0c3ca8f5aa919f1a32cf3a2461a74eb0c1b0f8b3563b757b1e0c9cd53068e79774da3ec0d652acbfddeb75420b670fe9b208313293600af",
    name: "Geth/v1.7.3-stable/darwin-amd64/go1.9.3",
    network: {
      localAddress: "[::1]:64498",
      remoteAddress: "[::1]:30303"
    },
    protocols: {
      eth: {
        difficulty: 65536,
        head: "0x7d416a4ed27810d9154d9407a9b2b8ea4094fe8c5ce1d87e50bf6016d6b75a26",
        version: 63
      }
    }
}, {
    caps: ["eth/62", "eth/63", "par/1", "par/2", "pip/1"],
    id: "c2b237a4fabf631170f058f54f1aa685b7893ae75ff6260aa08e0698fd636573cae7bd1c303d41927aeebc46c5aebb8888994201226fff29c4664d9099b0281b",
    name: "Parity/v1.8.7-stable-e322fd8-20180124/x86_64-linux-gnu/rustc1.23.0",
    network: {
      localAddress: "100.100.34.41:64751",
      remoteAddress: "109.230.215.17:30304"
    },
    protocols: {
      eth: "handshake"
    }
}]

至此,一个有两个互联节点的以太坊链就成功搭建起来了。

挖矿

搭建起来的第一件事就是挖矿,在随便一个节点上执行

>  miner.start(1)

null

挖矿便开始了,随后风扇呜呜的声音就起来了
此时查看挖到的块数

> eth.blockNumber
0

发现开始0

为了能查看进度,执行

tail -f ~/geth/logs/console.log

或者

tail -f ~/geth/logs/console2.log

取决于你用哪个节点挖矿

出现如下输出

INFO [02-11|18:09:52] Generating DAG in progress               epoch=0 percentage=29 elapsed=35.565s
INFO [02-11|18:09:53] Generating DAG in progress               epoch=0 percentage=30 elapsed=36.822s
INFO [02-11|18:09:54] Generating DAG in progress               epoch=0 percentage=31 elapsed=38.024s
INFO [02-11|18:09:55] Generating DAG in progress               epoch=0 percentage=32 elapsed=39.206s
INFO [02-11|18:09:56] Generating DAG in progress               epoch=0 percentage=33 elapsed=40.389s
INFO [02-11|18:09:58] Generating DAG in progress               epoch=0 percentage=34 elapsed=41.649s
INFO [02-11|18:09:59] Generating DAG in progress               epoch=0 percentage=35 elapsed=42.837s
INFO [02-11|18:10:00] Generating DAG in progress               epoch=0 percentage=36 elapsed=43.992s
INFO [02-11|18:10:01] Generating DAG in progress               epoch=0 percentage=37 elapsed=45.181s
INFO [02-11|18:10:02] Generating DAG in progress               epoch=0 percentage=38 elapsed=46.317s
INFO [02-11|18:10:04] Generating DAG in progress               epoch=0 percentage=39 elapsed=47.516s
INFO [02-11|18:10:05] Generating DAG in progress               epoch=0 percentage=40 elapsed=48.662s

当percentage=100的时候,挖矿便开始了,稍等一会之后,再执行

> eth.blockNumber
4
> eth.blockNumber
5

发现已经挖到了,为了风扇废掉,及时停止了挖矿

> miner.stop()

true

查看区块的信息

查看最后一个区块的信息

> eth.getBlock(eth.blockNumber)
{
  difficulty: 131904,
  extraData: "0xd883010703846765746887676f312e392e338664617277696e",
  gasLimit: 3187903,
  gasUsed: 0,
  hash: "0xbd6806c5a0c5f9e43106e0f55dfc5db1765ad89c9a72962b8e7a0b54ca53ee2b",
  logsBloom: "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
  miner: "0xb6e09535504452d5f1be75b510944fa5942efb08",
  mixHash: "0x4951508a4d389ae7358154c332be764f80276c36823affb5bafb1b401d0602c2",
  nonce: "0x47c27c170524dd8f",
  number: 15,
  parentHash: "0xe4b8d62f2e765c5e89eb9f46757e350a6abc199afb3d0066ef3c6631b06a64b5",
  receiptsRoot: "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
  sha3Uncles: "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347",
  size: 536,
  stateRoot: "0xcbe4197bbedb50693d3dc41a8cf36b418b3bd853cafcf598abdb78778d0cf9c0",
  timestamp: 1518343931,
  totalDifficulty: 2037440,
  transactions: [],
  transactionsRoot: "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",
  uncles: []
}

拿到挖到最后一个区块的矿工的名字

> eth.getBlock(eth.blockNumber).miner
"0xb6e09535504452d5f1be75b510944fa5942efb08"

查找该矿工总共有多少以太坊币

> eth.getBalance(eth.getBlock(eth.blockNumber).miner)
75000000000000000000

注意次数的以太币单位为Wei,是最小的不可分的单位,10^18个wei是一个以太币,故而上述矿工总共有75个以太币,因为总共有15个区块被挖出来,按照每个区块奖励5个以太币的设定,正好75个以太币。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351

推荐阅读更多精彩内容

  • 以太坊(Ethereum ):下一代智能合约和去中心化应用平台 翻译:巨蟹 、少平 译者注:中文读者可以到以太坊爱...
    车圣阅读 3,737评论 1 7
  • 以太坊白皮书地址:https://github.com/ethereum/wiki/wiki/White-Pape...
    rectinajh阅读 17,809评论 0 46
  • 【中文版】以太坊白皮书 翻译:少平、 Seven当中本聪在 2009 年 1 月启动比特币区块链时,他同时向世界引...
    __Seven__阅读 4,165评论 0 10
  • 一、快速术语检索 比特币地址:(例如:1DSrfJdB2AnWaFNgSbv3MZC2m74996JafV)由一串...
    不如假如阅读 15,913评论 4 87
  • 圣灵是启动基督徒生命的大能,今晚我们恢复了家庭的祷告祭坛,因着这段时间放纵追剧猎场,常常看完后内心是自责的。东哥今...
    默想者阅读 599评论 0 0