1. 测试网络
可以使用以下命令将以太坊的 Go 语言客户端 Geth 连接到测试网络
[admin@daolian ~]$geth --testnet
下图显示了示例输出,该图显示了所选网络的类型以及有关区块链下载的其他各种信息。
Geth 客户端的下载地址如下:
https://geth.ethereum.org
用于测试网络的区块链浏览器可从以下网址获得:
https://ropsten.etherscan.io
该浏览器可用于跟踪以太坊测试网络中的交易和区块。
此外,也有其他测试网络可用,如 Frontier、Morden、Ropsten 和 Rinkeby。可以向 Geth 发出命令行标志以连接到所需的网络:
2. 建立以太坊私有网络
私有网络允许创建一个全新的区块链,这与测试网络或主网都有所不同,因为它使用了自己的创世块和网络 ID。为了创建私有网络,需要 3 个组件:
- 网络 ID
- 创世文件
- 存储区块链数据的数据目录。虽然对数据目录并未做严格的要求,但是如果系统上已经有多个处于活动状态的区块链,则应指定数据目录,以便将单独的目录用于新的区块链。
在主网上,以太坊 Geth 客户端默认情况下能够发现引导节点(Boot Node),因为它们在 Geth 客户端中被硬编码并自动连接;但是在私有网络上,需要通过指定适当的标志和配置来设置 Geth,以便它能够被其他对等方发现或能够发现其他对等方。
除了上面提到的 3 个组件,最好还要禁用节点发现(Node Discovery) ,以使互联网上的其他节点无法发现你的私有网络,这样它就是安全的。如果其他网络恰好具有相同的创世文件和网络 ID,则它们可能会连接到你的私有网络。具有相同网络 ID 和创世区块的机会非常少,尽管如此,还是建议禁用节点发现功能。
2.1 网络 ID
网络 ID 可以是 1 和 3 以外的任何正数,因为 1 和 3 已经分别被以太坊主网和测试网使用。在下面的示例中,为私有网络选择的网络 ID 是 786。
2.2 创世文件
创世文件(Genesis File) 包含自定义创世区块所需的必要字段,这是网络中的第一个区块,并且不指向任何先前的区块。以太坊协议将执行检查以确保互联网上没有其他节点可以参与共识机制,除非它们具有相同的创世区块。网络 ID 通常用作网络的标识。
以下显示了一个自定义的创世文件,该文件在后面的示例中会用到:
另外,可以通过指定收款人的地址和 Wei 数量的方式来预先分配以太币,但是一般来说并不需要这样做,因为在私有网络上可以非常快地开采以太币。
要预先分配以太币,可以将其添加到创世文件中,如下所示:
“alloc”:{
"0xcf61d213faa9acadbf0d110e1397caf20445c58f":{"balance":"100000"},
}
现在来看看这些参数的含义:
- nonce (随机数):这是一个 64 位哈希值,用于证明 PoW 已充分完成。该参数可与 mixhash 参数结合使用。
- timestamp (时间戳):这是该区块的 UNIX 时间戳,用于验证区块的顺序并用于难度调整。例如,如果生成区块的速度太快,则难度会更高。
- parentHash (父哈希):由于创士块没有父代,因此对于该区块来说,该参数的值始终为 0。
- extraData (额外数据):该参数允许将 32 位任意值与区块一起保存。
- gasLimit (燃料限制):这是每个区块燃料消耗的限制。
- difficulty (难度):此参数用于确定挖矿目标,它代表证明 PoW 所需的哈希难度级别。
- mixhash (混合哈希):这是一个 256 位哈希,可与 nonce 结合使用,以证明已花费了足够数量的计算资源来满足 PoW 要求。
- coinbase (币基):这是成功挖矿后将挖矿奖励发送到的 160 位地址。
- alloc (分配):此参数包含预分配的钱包列表。它采用长十六进制格式的帐户,然后将余额分配到其中。
- config(配置):此部分包括各种配置信息,这些信息将定义网络 ID 和区块链硬分叉区块编号。在私有网络中不需要使用此参数。
2.3 数据目录
这是用于保存以太坊网络的区块链数据的目录。例如,在下面的示例中,该目录是~/etherprivate/。
在 Geth 客户端中,还指定了许多参数以启动(或进一步微调配置) 私有网络。
2.4 标志及其含义
以下是与 Geth 客户端一起使用的标志(Flags):
- --nodiscover:此标志禁用了节点发现,可确保如果碰巧有相同的创世文件和网络 ID 时,无法自动发现该节点。
- --maxpeers:此标志用于指定允许连接到私有网络的对等者(Peers) 的数量。如果将其设置为 0,则将没有人能够连接,这在某些情况下(例如私有测试)可能是比较理想的。
- --rpc:用于在 Geth 中启用 RPC 接口。
- --rpcapi:此标志采用允许使用的 API 列表作为参数。例如,Eth 和 Web3 将通过 RPC 启用 Eth 和 Web3 接口。
- rpcport:这将设置 TCP RPC 端口,如 9999。
2.5 静态节点
如果需要连接到一组特定的对等方,则可以将这些节点添加到保存 chaindata 和 keystore 文件的文件夹。
3. 启动私有网络
启动私有网络的初始命令如下所示:
这将产生如下图所示的输出:
如下图所示,这将为正在运行的私有网络会话打开交互式 JavaScript 控制台。
挖矿开始后,将首次生成有向非循环图(Directed Acyclic Graph,DAG),并产生类似于下图所示的输出
一旦 DAG 生成完毕,即可开始挖矿,Geth 将产生类似于下图所示的输出。在这里可以清楚地看到 Mined 5 blocks back...(已开采 5 个区块)这类的消息。
查看可用对象列表有一个通用技巧,那就是依次按下键盘上的空格键两次和 Tab 键两次。这样将显示可用对象的完整列表,如下图所示:
此外,输入命令后,可以通过按下两次 tab 键自动完成命令。如果按下两次 Tab 键,则还会显示可用方法的列表,如下图所示:
除了上面提到的命令外,为了获得对象可用方法的列表,在输入命令后,还可以输入分号(;)。下图就是一个示例,它显示了适用于 net 的所有方法的列表。
3.1 在私有网络上运行 Mist
该消息如下图所示
这将允许连接到正在运行的私有网络 Geth 会话,并提供所有功能,例如通过 Mist 在私有网络上进行钱包、帐户管理和合约部署等操作,如下图所示:
一旦启动以太坊 Mist 浏览器,它将显示如下图所示的界面,以红底白字明确表示它正在 PRIVATE-NET (私有网络) 模式下运行。
3.2 使用 Mist 部署合约
作用 Mist 部署新合约非常容易。Mist 提供了一个界面,可以在访界面中以 Solidity 语言编写合约,然后将其部署在网络上。
接下来,我们将进行一项简单合约的练习,该合约可以对输入参数执行各种简单的算术计算。以下显示了使用 Mist 部署此合约的步骤。
在 Mist 浏览器的 CNTRACTS (合约)部分下,将上述源代码复制到其中,如下图所示:
在左侧复制了源代码之后,一旦验证通过,并且未检测到语法错误,则部署合约的选项将显示在右侧的下拉菜单中,它显示的是 SELECT CONTRACT TO DEPLOY(选择要部署的合约)。只需选择合约,然后单击屏幕底部的 Deploy (部署)按钮即可。
Mist 将向你询问帐户密码,并显示一个如下图所示的窗口。
输入帐户密码,然后单击 SEND TRANSACTION (发送交易)以部署合约。
成功部署和挖矿后,合约将出现在 Mist 的交易列表中,如下图所示:
合约可用后,可以通过 Mist 使用可用的函数进行交互。这些函数显示在右侧下拉列表中,如下图所示:
在上图中,可以看到 READ FROM CONTRACT (从合约中读取) 和 WRITE TO CONTRACT (写入合约) 选项。在右侧可以看到合约公开的函数。选择所需的函数后,即可为该函数输入适当的值,并在 Execute From (执行自) 下选择帐户,然后单击 EXECUTE (执行) 按钮以执行交易,这将导致调用选定的合约函数。
下图显示了此过程
如上图所示,为该帐户输入适当的密码,然后单击 SEND TRANSACTION (发送交易) 将该交易发送到合约。
3.3 私有网络/本地以太坊的区块浏览器
本地以太坊区块浏览器是一个有用的工具,可用于浏览本地私有网络区块链。
注意: Github 上有一个开源的免费区块浏览器,网址如下: https://github.com/etherparty/explorer |
该区块浏览器的安装步骤如下:
(1)在 Linux Ubuntu 计算机或 macOS 系统上运行以下命令:
[admin@daolian ~]$git clone https://github.com/etherparty/explorer
这将显示类似于以下内容的输出:
Cloing into 'explorer' ...
remote: Counting objects: 269, done.
remote: Total 269 (delta 0), reused 0 (delta 0),pack-reused 269
Receiving objects: 100% (269/269),59.41 KiB | 134.00 KiB/s, done.
Resolving deltas: 100% (139/139), done.
(2) 将目录更改为 explorer 并运行以下命令:
[admin@daolian ~]$cd explorer/
[admin@daolian ~]$npm start
注意: 如果正在使用的计算机上需要安装 Node.js, 则可以查看官方网站上的安装说明并下载节点。官方网址如下: https://nodejs.org/en/ |
一旦安装完成(可能需要接近 5 分钟),将显示类似于下图所示的输出,其中,将启动以太坊浏览器的 HTTP 服务器。
(3)Web 服务器启动后,应使用以下命令启动 Geth:
[admin@daolian ~]$geth --datadir .ethereum/privatenet/ --networkid 786 --rpc --rpccorsdomain 'http://localhost:8000'
也可以使用以下命令:
[admin@daolian ~]$geth --datadir .ethereum/privatenet/ --networkid 786 --rpc --rpccorsdomain '*'
(4)成功启动 Geth 之后,导航到 TCP 端口 8000 上的 localhost,如下图所示,以便访问本地以太坊区块浏览器。
也可以使用 Python 或任何其他适当的提供程序来启动 Web 服务器。当使用 Python 时,可以启动一个快速的 Web 服务器,如以下代码所示:
[admin@daolian ~]$python -m SimpleHTTPServer 7777
Serving HTTP on 0.0.0.0 port 7777 ...
Geth 客户端将需要使用适当的参数启动,否则可能会发生错误,如下图所示:
重新启动 Geth 以允许 rpccorsdomain:
[admin@daolian ~]$./geth --datadir ~/etherprivate/ --networkid 786 --rpc --rpcapi 'web3,eth,net,debug,personal' --rpccorsdomain '*'
注意: * 表示任何 IP 都可以连接,也可以使用计算机的本地 IP 地址 |