以太坊是区块链2.0时代的代表,也是全球第一个ICO项目。
以太坊(Ethereum):是一个开源的有智能合约功能的公共区块链平台,通过其专用加密货币以太币(Ether)提供去中心化的以太虚拟机(Ethereum Virtual Machine)来处理点对点合约,属于区块链2.0架构。
从上述的定义可以看出以太坊和比特币相似,都是一个基于区块链技术的分布式计算平台。不过它更强调自己是一个智能合约系统,其实它的本质和比特币是一样的。只不过可以在这个平台里任意生成多个不同的比特币系统而已。
以太坊涉及到三个基本概念:
比特币存在的不足:
以太坊的优化:
下面三个版本的以太坊的共识机制均采用PoW,目前来看正在往混合共识机制转换,以太坊的混合共识机制是PoW+POS,从而使矿工与持币者的利益得到平衡。
智能合约:指的是由计算机程序定义、可自动执行的承诺和协议。
以太坊智能合约:代码(即合约功能)和数据(即合约状态)的集合,存在于以太坊区块链的特定地址。合约账户能够在彼此之间传递信息,进行图灵完备的运算。合约依靠以太坊虚拟机(EVM)以字节代码的二进制格式在区块链运行。
以太坊智能合约可以分为5种:
优点:
在部署智能合约之前,需要两件事情:编译代码和应用程序的二进制接口,二进制接口是一种参考模板,用于定义如何与合同进行交互。
安装智能合约编译工具solc,solc是一个Solidiy命令行编译器,是Solidity编译方法之一。
在ubuntu系统,在终端输入命令行就可以成功安装。
在Ubuntu系统
在终端中执行以下命令:
sudo add-apt-repository ppa:ethereum/ethereum
sudo apt-get update
sudo apt-get install solc
which solc
在MAC OSX系统,也是在终端输入命令行。
在Mac OSX系统中
在终端中执行以下命令:
brew tap ethereum/ethereum
brew install solidity
which solc
在Windows系统中,需要安装chocolatey,该工具可以在windows上管理软件,然后执行命令行就可以了。
在Windosw系统中
需要安装chocolatey (https/chocolsteyorg/),该工具可以在windows上管理软件。
在终端中执行以下命令:
cinst -pre solC-stable
最后是通过源码安装solc。
在终端中执行以下命令:。
git clone https://github.com/ethereum/cpp-ethereum.git
mkdir cpp-ethereum/build
cd cpp-ethereum/build
cmake -DISONRPC=OFF -DMINER=OFF -DETHKEY=OFF -DSERPENT=OFF-DGUI=OFF -DTESTS=OFF -DJSCONSOLE=OFF
make -j4
make install
which solc
在命令行输入下面的bin命令进行智能合约代码solc编译:
solc --bin HelloWorld.sol
除了字节码数据,还需要一个abi接口,通过执行abi命令:
solc --bin HelloWorld.sol
得到abi信息,在之后的测试部署中可能会用到。
以下是智能合约示例
pragma solidity ^0.4.20;
contract Simplestorage {
uint storedData;
function set(uint x){
storedData= x;
}
function get() constant returns(uint){
return storedData;
}
}
三种智能合约测试的方式:
Remix+MetaMask
wallet +MetaMask
truffle
智能合约测试工具安装及使用
传统意义上的虚拟机
虚拟机:实际上不是物理计算机,而是一个用来模仿物理计算机的软件环境,但虚拟机可以像物理计算机一样运行程序。用于托管虚拟机的物理计算机通常可以支持多台虚拟机。另外,不仅在系统层上有虚拟机的概念,在程序语言上也有虚拟机的概念。
虚拟机是用来解决什么问题呢?
为了抽象掉硬件底层。从系统层来说,硬件和操作系统都越来越多样化了。
它可以自动兼容所有硬件。总结一下,虚拟机技术实现基本上都是将硬件层或是系统层进行了一次抽象,以致对应用层屏蔽掉了底层的实现细节,有利于应用的快速实现和部署。
按层次来说可以分为三大类:
然而它们的实现越往底层难度就越大。
传统的精简指令集计算机:这种计算机CPU只提供了有限的执行指令和存储器,但是各种类型的应用都能在这台计算机上运行。
原理:因为系统存在一个“虚拟机”将高层语言的实现都转换成了CPU的相关执行指令。高层语言提供语法,人们使用高级语言开发相关应用。
由低到高的层次结构分别为:硬件指令,虚拟机,高级语言和应用层。
如果要在区块链里支持各种应用,也需要有这样的层次结构,因此需要区块链提供一套指令,并且区块链里的虚拟机可以对这些指令作相关的解释。另外,高级语言的实现需要有一个编译器将实现编译成虚拟机支持的指令。这样,区块链就完美支持了语言和业务的分离,从而可以在区块链里开发各种业务应用。
虚拟机架构的组成部分:
还有两个重要的组成部分∶
当所有的部分都就绪后,我们就可以用高级语言和API编写符合业务逻辑的智能合约,然后用相关编译器将智能合约编译成 byte codes,并且也会生成相关的ABI描述。经过严格测试后,就可以将智能合约的byte codes和ABI以交易的形式发布到区块链中。
矿工会验证你交易的合法性,如果入块成功,将会返回智能合约地址。用户会调用这个合约地址来获取 ABI,再根据 ABI 里对功能接口的描述来发起—笔对功能接口调用的交易,从而实现相关功能或是获取相关结果。矿工同样也会对这笔交易进行合法性验证及入块处理。
将经过严格测试的智能合约代码发布到区块链上可以理解为一个特殊的交易——包括了可执行代码的交易,然后会被矿工记录在某个块中。当需要调用这个智能合约时,只需向这个智能合约的地址发送一个交易即可。因为每个节点都需要安装以太坊客户端,而每个客户端都自带了一个EVM(以太坊虚拟机)。通过交易触发智能合约后,智能合约的代码就能在EVM上被执行。
这种方式相当于把程序部署到了很多的电脑上,随时都可以通过交易来触发这些智能合约的执行,从而也完成了去中心化程序的部署和调用。
DAPP就是基于以太坊运行的去中心化应用,这种应用涉及到传统行业的方方面面。
以太坊为什么需要共识机制呢?
分布式系统中多个主机通过异步通信的方式组成网络集群,在这样的一个异步系统中需要主机之间进行状态复制,以保证每个主机达成一致的状态共识。在运行的过程中,可能出现主机故障导致无法通信,也有可能主机性能下降、网络拥塞这些都可能导致错误信息在系统内传播,因此需要在不可靠的异步网络中定义容错协议以保证各主机达成安全可靠的状态共识。
以太坊共识机制的版本
如果单纯根据代币余额来决定记账者,必然使富有者胜出,导致记账权的中心化,降低共识的公正性。因此,如何解决记账权中心化问题?不同的PoS机制在权益证明的基础上,采用了不同的方式来增加记账权的随机性,来辟负中心化。
挖矿流程
共识机制:PoW(工作量证明)
算法:Ethash (Dagger-Hashimoto算法的改良版本)
对于每个块,首先计算一个种子,该种子仅和当前块的信息有关,然后根据种子生成一个32M的随机数据集,根据随机数据集生成一个1G大小的DAG(有向无环图)。
挖矿的过程就是从DAG中随机选择元素(类似于比特币挖矿中查找合适Nonce),再进行哈希运算,可以从Cache快速计算DAG指定位置的元素,进而哈希验证。
挖矿步骤