搭建测试网络和私有链
文章出于:http://wangxiaoming.com/blog/2016/07/08/e17/
测试网络
Morden测试网
Morden是公开的以太坊替代测试网。它会贯穿于整个软件里程碑Frontier和Homestead。
用法
eth (C++客户端) 0.9.93及以上版本自动支持。比如开启以下任意客户端时,通过—morden参数。
PyEthApp (Python客户端) PyEthApp支持v1.0.5以后的morden网络。
geth (Go客户端)
细节
除以下几条,所有参数都和主要的以太坊网络相同:
- 网络名称:Morden
- 网络身份:2
- genesis.json(如下);
- 初始账户随机数(IAN)是220 (不像之前的网络中是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"难度能让你再私有测试网链上快速挖以太币。如果你创建了自己的链,开始挖矿,你应该几分钟就会有上百个以太币,远远超过了在网络上测试交易所需的数量。如果你还想给账户预分配以太币,就需要:
- 创建私有链以后再创建新的以太坊账户。
- 复制新的账户地址。
在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是以太坊货币以太币的最小面额(参见以太币)。