第五章 搭建测试网络和私有链
5.1 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龙头。
5.2 设置本地私有测试网
eth (C++客户端)
可以使用 –genesis
和 –config
连接到或创建一个新的网络。
可以同时使用 –config
和 –genesis
。
那样的话,–config
提供的初始区块描述会被–genesis选项覆盖。
注意:<filename>
包含一个网络的 JSON描述。
- • sealEngine(用来在区块挖矿的引擎)“Ethash”是以太坊工作量证明引擎(用于实时网络)。 “NoProof”在区块挖矿不需要工作量。
- • params(诸如 minGasLimit, minimumDifficulty, blockReward, networkID等一般的网络信息)
- • genesis(初始区块描述)
- • accounts(设置包含账户/合约的初始状态)
这是一个 Config 的例子(用于 Olympic网络):
注意:<filename>
包含一个网络的 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如果你不希望其他人连接到你的测试链,可以使用 maxpeers0。反之,如果你确切知道希望多少人连接到你的节点,你也可以通过调整数字来实现。
--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": { "<your account address e.g. 0x1fb891f92eb557f4d688463d0d7c560552263b5a>": { "balance": "20000000000000000000" } }
注意:用你的账户地址取代 0x1fb891f92eb557f4d688463d0 d7c560552263b5a
保存初始文件,重新运行私有链指令。Geth完整装载以后,关闭它。我们想指派一个地址给变量 primary,查看它的余额。在终端运行 gethaccount 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是以太坊货币以太币的昀小面额(参见以太币)。
- https://www.reddit.com/r/ethereum/comments/3kdnus/question_about_pr ivate_chain_mining_dont_upvote/
- http://adeduke.com/2015/08/how-to-create-a-private-ethereum-chain/