搭建测试网络和私有链

测试网络

Morden测试网

Morden是公开的以太坊替代测试网。它会贯穿于整个软件里程碑Frontier和Homestead。

用法

eth (C++客户端) 0.9.93及以上版本自动支持。比如开启以下任意客户端时,通过—morden参数。

PyEthApp (Python客户端) PyEthApp支持v1.0.5以后的morden网络。

geth (Go客户端)

细节

除以下几条,所有参数都和主要的以太坊网络相同:

  • 网络名称:Morden
  • 网络身份:2
  • genesis.json(如下);
  • 初始账户随机数(IAN)是2^20 (不像之前的网络中是0)

– 状态树形结构中的所有账户都有随机数>= IAN。

– 账户被插入到状态树形结构中时,都会被赋予一个初始随机数= IAN。

  • 初始通用区块哈希值: 0cd786a2425d16f152c658316c423e6ce1181e15c3295826d7c9904cba9ce303
  • 初始通用状态根:f3f4696bbf3b3b07775128eb7a3763279a394e382130f27c21e70233e04946a9

Morden的genesis.json

获取Morden测试网以太币

有两种方法可以获取Morden测试网以太币:

  • 用CPU/GPU挖矿(参见挖矿)。
  • 用以太坊wei龙头。

设置本地私有测试网

eth (C++ 客户端)

可以使用–genesis和–config连接到或创建一个新的网络。

可以同时使用–config和–genesis。

那样的话,–config提供的初始区块描述会被–genesis选项覆盖。

注意:包含一个网络的JSON描述。

  • sealEngine (用来在区块挖矿的引擎)

    “Ethash”是以太坊工作量证明引擎(用于实时网络)。

    “NoProof” 在区块挖矿不需要工作量。

  • params (诸如minGasLimit, minimumDifficulty, blockReward, networkID等一般的网络信息)

  • genesis (初始区块描述)

  • accounts (设置包含账户/合约的初始状态)

这是一个Config的例子(用于Olympic网络):

注意:包含一个网络的JSON描述。

内容与’config’参数提供的初始领域相同。

geth (Go客户端)

你可以在私有测试网上生成或挖掘自己的以太币。这个试验以太坊方法很划算,可以避免不得不挖矿,或找到Morden测试网络的以太币。

在私有链中需要详细说明的事件有:

  • 定制初始文件
  • 定制数据目录
  • 定制网络ID
  • (推荐) 废弃节点发现

初始文件

初始区块是区块链的起始 — 第一个区块,区块0,唯一没有指向前面区块的一个区块。协议确保其他节点不会和你的区块链一致,除非他们和你有相同的初始区块,这样你想创建多少私有测试网区块链,就可以创建多少!

{
"nonce": "0x0000000000000042", "timestamp": "0x0",
"parentHash": "0x0000000000000000000000000000000000000000000000000000000000000000",
"extraData": "0x0", "gasLimit": "0x8000000", "difficulty": "0x400",
"mixhash": "0x0000000000000000000000000000000000000000000000000000000000000000",
"coinbase": "0x3333333333333333333333333333333333333333", "alloc": { }
}

存储文件为CustomGenesis.json。用下面的标志启动geth节点的时候,你会引用到这个。

--genesis /path/to/CustomGenesis.json

私有网络的命令行参数

有一些必需的命令行选项(又称为“标志”)来确保你的网络是私有的。我们已经谈到了初始标志,下面还有几个。注意所有下面的指令都会用在geth以太坊客户端。

--nodiscover

使用这个命令可以确保你的节点不会被非手动添加你的人发现。否则,你的节点可能被陌生人的区块链无意添加,如果他和你有相同的初始文件和网络ID。

--maxpeers 0

如果你不希望其他人连接到你的测试链,可以使用maxpeers 0。反之,如果你确切知道希望多少人连接到你的节点,你也可以通过调整数字来实现。

--rpc

这个指令可以激活你节点上的RPC界面。它在geth中通常被默认激活。

--rpcapi "db,eth,net,web3"

这个命令可以决定允许什么API通过RPC进入。在默认情况下,geth可以在RPC激活web3界面。

重要信息:请注意在RPC/IPC界面提供API,会使每个可以进入这个界面(例如dapp’s)的人都有权限访问这个API。注意你激活的是哪个API。Geth会默认激活IPC界面上所有的API,以及RPC界面上的db,eth,net和web3 API。

--rpcport "8080"

将8000改变为你网络上开放的任何端口。Geth的默认设置是8080.

--rpccorsdomain "http://chriseth.github.io/browser-solidity/"

这个可以指示什么URL能连接到你的节点来执行RPC定制端任务。务必谨慎,输入一个特定的URL而不是wildcard ( * ),后者会使所有的URL都能连接到你的RPC实例。

--datadir "/home/TestChain1"

这是你的私有链数据所储存在的数据目录(在nubits下)。选择一个与你以太坊公有链文件夹分开的位置。

--identity "TestnetMainNode"

这会为你的节点设置一个身份,使之更容易在端点列表中被辨认出来。这个例子说明了这些身份如何在网络上出现。

发布geth

你创建了定制初始区块JSON并建立区块链数据目录后,在控制台输入以下指令,进入geth:

geth --identity "MyNodeName" --genesis /path/to/CustomGenesis.json --rpc --rpcport "8080" --rpcco

注意:请改变标志与定制设置匹配。

每次想要进入定制链的时候,你都需要用定制链指令启动geth实例。如果你只在控制台输入“geth”,它不会记住你设置的所有标志。

给账户预分配以太币

“0x400”难度能让你再私有测试网链上快速挖以太币。如果你创建了自己的链,开始挖矿,你应该几分钟就会有上百个以太币,远远超过了在网络上测试交易所需的数量。如果你还想给账户预分配以太币,就需要:

  1. 创建私有链以后再创建新的以太坊账户。
  2. 复制新的账户地址。
  3. 在Custom_Genesis.json文件中添加以下指令:
"alloc":
{
"":
{ "balance": "20000000000000000000" }
}

注意:用你的账户地址取代0x1fb891f92eb557f4d688463d0
d7c560552263b5a

保存初始文件,重新运行私有链指令。Geth完整装载以后,关闭它。

我们想指派一个地址给变量primary,查看它的余额。

在终端运行geth account list指令,查看指派给你的新地址账户号码是什么。

> geth account list

Account #0: {d1ade25ccd3d550a7eb532ac759cac7be09c2719}
Account #1: {da65665fc30803cb1fb7e6d86691e20b1826dee0}
Account #2: {e470b1a7d2c9c5c6f03bbaa8fa20db6d404a0c32}
Account #3: {f4dd5c3794f1fd0cdc0327a83aa472609c806e99}

记录你预分配以太币的账户号码。或者,可以用geth console(和最先启动geth时保持一样的参数)启动控制台。提示出现以后,输入

> eth.accounts

这会返回到你拥有的账户地址排列。

> primary = eth.accounts[0]

注意:用你的账户指数取代0,这个控制台指令会返回到你第一个以太坊地址。

输入以下指令:

> balance = web3.fromWei(eth.getBalance(primary), "ether");

这应该会返回到7.5,意味着你账户里有那么多以太币。我们必须在你初始文件的分区里放那么多数量是因为“余额”领域以wei为单位取一个数字,wei是以太坊货币以太币的最小面额(参见以太币)。

你可能感兴趣的:(区块链)