以太坊连载(17):搭建测试网络和私有链
测试网络 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节点的时候,你会引用到这个。 1 --genesis /path/to/CustomGenesis.json 私有网络的命令行参数 有一些必需的命令行选项(又称为“标志”)来确保你的网络是私有的。我们已经谈到了初始标志,下面还有几个。注意所有下面的指令都会用在geth以太坊客户端。 1 --nodiscover 使用这个命令可以确保你的节点不会被非手动添加你的人发现。否则,你的节点可能被陌生人的区块链无意添加,如果他和你有相同的初始文件和网络ID。 1 --maxpeers 0 如果你不希望其他人连接到你的测试链,可以使用maxpeers 0。反之,如果你确切知道希望多少人连接到你的节点,你也可以通过调整数字来实现。 1 --rpc 这个指令可以激活你节点上的RPC界面。它在geth中通常被默认激活。 1 --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。 1 --rpcport "8080" 将8000改变为你网络上开放的任何端口。Geth的默认设置是8080. 1 --rpccorsdomain "http://chriseth.github.io/browser-solidity/" 这个可以指示什么URL能连接到你的节点来执行RPC定制端任务。务必谨慎,输入一个特定的URL而不是wildcard ( * ),后者会使所有的URL都能连接到你的RPC实例。 1 --datadir "/home/TestChain1" 这是你的私有链数据所储存在的数据目录(在nubits下)。选择一个与你以太坊公有链文件夹分开的位置。 1 --identity "TestnetMainNode" 这会为你的节点设置一个身份,使之更容易在端点列表中被辨认出来。这个例子说明了这些身份如何在网络上出现。 发布geth 你创建了定制初始区块JSON并建立区块链数据目录后,在控制台输入以下指令,进入geth: 1 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,查看它的余额。 在终端运行geth account list指令,查看指派给你的新地址账户号码是什么。 记录你预分配以太币的账户号码。或者,可以用geth console(和最先启动geth时保持一样的参数)启动控制台。提示出现以后,输入 1 > eth.accounts 这会返回到你拥有的账户地址排列。 1 > primary = eth.accounts[0] 注意:用你的账户指数取代0,这个控制台指令会返回到你第一个以太坊地址。 输入以下指令: 1 > balance = web3.fromWei(eth.getBalance(primary), "ether"); 这应该会返回到7.5,意味着你账户里有那么多以太币。我们必须在你初始文件的分区里放那么多数量是因为“余额”领域以wei为单位取一个数字,wei是以太坊货币以太币的最小面额(参见以太币)。 https://www.reddit.com/r/ethereum/comments/3kdnus/question_about_private_chain_mining_dont_upvote/ http://adeduke.com/2015/08/how-to-create-a-private-ethereum-chain/ |
2018-06-24
2018-11-20
2019-01-10
2019-01-10
2019-01-10
2019-11-14
2019-11-14
2019-11-14
2019-11-13