众所周知,区块链是一个类似于链表的结构,每一个区块都具有唯一的Hash值,后一个区块通过记录前一个区块的Hash值,来表明父子关系。一条区块链可以无限延伸,然而却一定要有一个开端,一个让这条区块链从无到有的区块,这个区块的名字就叫创世区块(Genesis Block)。创世区块最显著的特征就是没有父区块,通常创世区块不是由矿工挖掘出来的,而是预先生成好并将创世区块的Hash写进了钱包软件的代码中。
在以太坊钱包的官方实现Geth的代码中,我们可以找到这个创世区块的Hash。
源代码:params/config.go
var (
MainnetGenesisHash = common.HexToHash("0xd4e56740f876aef8c010b86a40d5f56745a118d0906a34e69aec8c0db1cb8fa3") // Mainnet genesis hash to enforce below configs on
TestnetGenesisHash = common.HexToHash("0x41941023680923e0fe4d74a34bdac8141f2540e3ae90623718e47d66d1ca4a2d") // Testnet genesis hash to enforce below configs on
)
其中的0xd4e56740f876aef8c010b86a40d5f56745a118d0906a34e69aec8c0db1cb8fa3就是创世区块的Hash了。到区块链浏览器中看一下,果然如此,高度为0的创世区块。
等等,下面那个TestnetGenesisHash = 0x41941023680923e0fe4d74a34bdac8141f2540e3ae90623718e47d66d1ca4a2d是什么鬼,为什么区块链浏览器中查不到?
前面说到一条区块链由一个创世区块开始,也就是说,一个创世区块可以创造和代表一条区块链。如果我们给钱包客户端设定不同的创世区块,它就将工作在不同的区块链上。
工作在同一条区块链上的全部节点,我们称之为一个网络。
绝大多数人在使用的网络被称为主网络(Mainnet),用户在其上交易、构建智能合约,矿工在其上挖矿。由于使用的人数众多,主网络的鲁棒性很强,能够对抗攻击,区块链也不易被篡改,因此主网络是具有功能的,其上的以太币是有价值的。
通常一种区块链只有一个主网络,比如比特币,莱特币,以太坊,都只有一个主网络。主网络之外可以有若干个测试网络。
既然已经有了一个主网络,为什么还要弄出测试网络呢?
我们先来讲一个故事。
(小王是一家软件公司的程序员,每天起得比鸡早,睡得比牛晚,可以说是兢兢业业。最近区块链技术比较火,老板想出了一个点子。)
老板:小王啊,你去在以太坊上给我开发个智能合约,咱也来个ICO。 小王:好的,老大。
(小王满口答应,然而他心里却在犯嘀咕,这活儿我没干过啊。没关系,工程师嘛,什么不能学呢?小王一个通宵,就把以太坊研究明白了,第二天找到老板。)
小王:老板,我需要一些以太币来测试。
(老板就是老板,大笔一挥,给了小王1000个以太币,拿去测试吧。小王满怀信心的按下了回车,突然,他意识到,程序出了bug,这1000个以太币将被永远锁定,无法再使用。小王垂头丧气的找到老板,祈求老板的原谅。)
老板:什么?1000个以太币被永远锁定了?没事儿,才值200w而已。
(小王满心欢喜,正想感谢老板的宽恕。老板一个诡异的微笑,看了一眼身后的保安。)
老板:拿他祭天吧。
(这天下午,在公司前面的广场上,员工们盛装华服,将小王绑在火刑架上,点燃柴堆。大家一起祈祷这次ICO可以成功,公司蒸蒸日上,程序再也没有bug。数日后的ICO发布会上,老板告诉投资人,他们一定能赚钱,因为我们“杀了个程序员祭天”。)
主网络中的以太币是有价值的,在主网络上直接进行钱包软件或者智能合约的开发将会是非常危险的,稍有不慎就会损失以太币,甚至影响整个主网络的运行。同时,因为主网络使用人数多,矿工更是不计其数,如果是在开发一个挖矿软件,用一台开发软件的笔记本电脑几乎不可能挖出一个区块,这就导致测试几乎不可行。
于是,出于测试和学习的目的,便会有一小部分节点,使用与主网络不同的创世区块,开启一条全新的区块链,并在上面挖矿和测试,这就是测试网络(Testnet)。
以太坊可以搭建私有的测试网络,不过由于以太坊是一个去中心化的平台,需要较多节点共同运作才能得到理想的测试效果,因此并不推荐自行搭建测试网络。
以太坊公开的测试网络共有4个,目前仍在运行的有3个。每个网络都有自己的创世区块和名字,按开始运行时间的早晚,依次为:
Morden是以太坊官方提供的测试网络,自2015年7月开始运行。到2016年11月时,由于难度炸弹已经严重影响出块速度,不得不退役,重新开启一条新的区块链。Morden的共识机制为PoW。
Ropsten也是以太坊官方提供的测试网络,是为了解决Morden难度炸弹问题而重新启动的一条区块链,目前仍在运行,共识机制为PoW。测试网络上的以太币并无实际价值,因此Ropsten的挖矿难度很低,目前在755M左右,仅仅只有主网络的0.07%。这样低的难度一方面使一台普通笔记本电脑的CPU也可以挖出区块,获得测试网络上的以太币,方便开发人员测试软件,但是却不能阻止攻击。
PoW共识机制要求有足够强大的算力保证没有人可以随意生成区块,这种共识机制只有在具有实际价值的主网络中才会有效。测试网络上的以太币没有价值,也就不会有强大的算力投入来维护测试网络的安全,这就导致了测试网络的挖矿难度很低,即使几块普通的显卡,也足以进行一次51%攻击,或者用垃圾交易阻塞区块链,攻击的成本及其低廉。
2017年2月,Ropsten便遭到了一次利用测试网络的低难度进行的攻击,攻击者发送了千万级的垃圾交易,并逐渐把区块Gas上限从正常的4,700,000提高到了90,000,000,000,在一段时间内,影响了测试网络的运行。攻击者发动这些攻击,并不能获得利益,仅仅是为了测试、炫耀、或者单纯觉得好玩儿。
为了解决测试网络中PoW共识机制的问题,以太坊钱包Parity的开发团队发起了一个新的测试网络Kovan。Kovan使用了权威证明(Proof-of-Authority)的共识机制,简称PoA。
PoW是用工作量来获得生成区块的权利,必须完成一定次数的计算后,发现一个满足条件的谜题答案,才能够生成有效的区块。
PoA是由若干个权威节点来生成区块,其他节点无权生成,这样也就不再需要挖矿。由于测试网络上的以太币无价值,权威节点仅仅是用来防止区块被随意生成,造成测试网络拥堵,完全是义务劳动,不存在作恶的动机,因此这种机制在测试网络上是可行的。
Kovan与主网络使用不同的共识机制,影响的仅仅是谁有权来生成区块,以及验证区块是否有效的方式,权威节点可以根据开发人员的申请生成以太币,并不影响开发者测试智能合约和其他功能。
Kovan目前仍在运行,但仅有Parity钱包客户端可以使用这个测试网络。
Rinkeby也是以太坊官方提供的测试网络,使用PoA共识机制。与Kovan不同,以太坊团队提供了Rinkeby的PoA共识机制说明文档,理论上任何以太坊钱包都可以根据这个说明文档,支持Rinkeby测试网络,目前Rinkeby已经开始运行。
目前开发人员最常用的测试网络是Rinkeby,我将演示一种最简单的连接和使用Rinkeby的方法。
下载以太坊钱包:ethereum/mist
根据使用的操作系统不同,在下图红框中选择合适的版本,下载解压。
MIST其实只是以太坊钱包的一个图形界面,后端还是官方的Geth,只是可以使用图形化的方式操作,减少了出错的几率,降低使用门槛。MIST是使用Electron开发的,具有跨平台的能力,所以在各个系统上的界面和操作应该是基本一致的。
第一次启动时,记得选择测试网络。
在测试网络上创建一个钱包地址,并给钱包加个密码。
片刻之后,一个钱包地址就创建完成了,每个人的地址都不相同。由于是测试网络,地址不需要保密,我就不打马赛克了。
之后点击下面的“LAUNCH APPLICATION!”就可以进入主界面了。
注意:一定要确保左下角有个红色的Rinkeby字样,这表明你正在Rinkeby测试网络中。
点击右侧红框,就可以看到你的钱包地址的余额了,现在应该是0以太币。
首次启动时,需要同步区块链,这需要一段时间,大约1小时左右。
Rinkeby测试网络使用的是PoA共识机制,我们不能通过挖矿来获取以太币。
想获取Rinkeby测试网络中的以太币,需要去申请,这个申请Rinkeby以太币的功能被称为水龙头(Faucet)。还真是挺形象的,水龙头会源源不断的产生以太币,并且受到权威节点控制,以确保不会被滥用。
进入这个水龙头的网站:Rinkeby: GitHub Faucet
为了确保不会出现有人滥用水龙头,无限生成Rinkeby以太币,水龙头需要借助github账号来确定申请者的身份和配额。没有Github账号的小伙伴记得要去注册一个,并且登陆。
进入https://gist.github.com/,把测试钱包账户的地址粘贴进去,并点击“Create public gist”,就像下图这样。
点击之后,把浏览器上方的地址复制下来,粘贴到水龙头页面的输入框中。并点击“Give me Ether”,有三种选项,前面是获得的以太币数量,后面是冷却时间,在冷却时间过后才能进行下一次以太币申请。
如果一切顺利,你会看到你的钱包地址已经多出了申请数量的以太币,我申请了3个以太币。
到Rinkeby的区块链浏览器查看一下,也能查到我的钱包地址0xA54BF5C1059D24ac1943F332851a2F0779EDD026。
如果申请的人数很多,需要排队等待一会儿,我自己在使用过程中,最多等过半小时,申请的以太币金额越大,一般需要等待越多的时间才能到账。
为什么申请测试网络的以太币如此繁琐呢?
以太币在以太坊平台中的设计功能是用来支付EVM中执行指令消耗的Gas,如果可以被无限制的产生,就会出现有恶意用户出于各种目的,用无限制的以太币换无限制的Gas,在EVM中执行超多的指令,并逐渐抬高区块Gas上限。EVM中的指令要在每一个以太坊节点中执行,这种攻击一旦出现,对网络将会产生很大的影响,所以测试网络中的以太币必须针对每个开发者限量供应。不过这个限量对正常的开发测试来说,几乎不会造成影响。
如果你看到了这里,并且成功的在自己的电脑上运行了钱包、连接测试网络、申请以太币,那么恭喜你,你已经做好了进一步学习和了解以太坊的准备。之后的文章中,将会介绍如何编写一个智能合约,这是以太坊最重要的一项功能,敬请期待。