ASTO:聚焦系列5 ▏以太坊侧链——可扩展、安全、去中心化

以太坊侧链支持开发人员在以太坊虚拟机(EVMs)上编码、部署和运行他们的智能合约。

以太坊区块链是什么?

以太坊区块链是一个平台,它为开发人员提供了使用区块链技术构建去中心化应用程序的工具。以太坊提供了一个类似于比特币的平台,以ETH为媒介进行点对点的去中心化交易。除了数字货币,以太坊还可以在没有任何第三方的情况下运行智能合约,这不仅允许它构建与货币相关的应用程序,还可以构建金融、音乐、游戏和所有迭代和细分市场的应用程序。

在以太坊区块链上,矿工们通过工作来获取以太坊的Token——ETH,为整个以太坊网络提供“Gas”。开发人员还使用ETH来支付以太坊网络的交易费用和服务费用。“Gas”用来测量计算一个以太坊节点所需要的能量。用户使用ETH付费,然而,计算是根据执行某个操作代码需要多少“Gas”来完成的。因此,每一个智能合约的执行都需要一定数量的“Gas”与之一起发送。

什么是Elastos主侧链架构?

与以太坊等使用单一区块链层执行每个事务的传统区块链平台相比,Elastos采用了独特的框架——主侧链架构,来支持其区块链平台。主链主要负责支付交易,侧链则是为满足特定的服务而开发。例如:DID侧链为用户提供了一种独特的方法来获得不受任何第三方控制的去中心化的身份认证;Token侧链允许用户创建他们自己的唯一Token;NEO侧链允许开发人员在NEO虚拟机上编码、部署和运行他们的智能合约。

最后,以太坊侧链允许开发人员在以太坊虚拟机(EVMs)上编码、部署和运行他们的智能合约。要更详细地了解Elastos侧链的工作原理,请阅读:《聚焦系列2:亦来云侧链和可扩展性解决方案》。

主侧链架构

为什么我们需要Elastos?

Elastos有一个独特的区块链架构,每条侧链都有其特定的功能。以太坊侧链的功能是允许现有的以太坊开发人员在以太坊侧链上快速的部署他们自己的智能合约。这意味着,如果已经有人使用可编程语言在以太坊区块链上部署智能合约,那么他们无需进行大量工作,就可以轻松地将这些智能合约移植到Elastos的以太坊侧链上。并且Elastos以太坊侧链不仅有可以使智能合约移植到Elastos生态系统上这一功能,Elastos以太坊侧链与以太坊区块链不同的是,Elastos采用DPoS共识机制,从而显著增加了TPS(每秒系统处理事务数)。截止到2019年9月,Elastos的DPoS共识机制得到了流通中的ELA超过40%的投票支持。Elastos以太坊侧链作为一个独立的区块链,即侧链,具有优越的可扩展性能和安全性。

截止到2019年9月,Elastos的DPoS共识机制得到了流通中的ELA超过40%的投票支持。

Elastos以太坊侧链具有以下特点:

1.解决以太坊区块链拥堵问题

以太坊区块链作为一个单一的主链结构,导致了计算能力的上限。尽管以太坊区块链中有数千个计算节点,但数据处理速度受到链中单个节点的限制,仅用一条链来满足未来的各种需求几乎是不可能的。Elastos采用了灵活的主链和侧链设计结构。主链只负责基本的交易支付,而Elastos以太坊侧链执行EVM兼容的智能合约来支持各种应用程序和服务。

2.交易回报

以太坊区块链中的矿工通过向区块链生成、签名和发布块获得奖励(ETH),而在Elastos上,来自主链的DPoS超级节点负责侧链生成、签名和发布块。在这个系统中,没有矿工去争夺以太坊侧链的计算能力和挖矿奖励。DPoS超级节点的回报来自交易费用。此外,在这个系统中,矿工不需要购买采矿机器和使用大量的电力,这最终降低了交易费用。这就是为什么Elastos以太坊侧链提供了卓越的可扩展性潜力和更便宜的智能合约部署的原因。

3.共享比特币算力

通过与比特币联合挖矿获得比特币算力的强大保护。截止到2019年9月,Elastos区块链拥有BTC超过50%的算力。

4.ELA支付Gas费用

使用ELA支付所有以太坊侧链的Gas费用。

火币联合创始人杜均:聚焦合规业务拓展海外业务:10月7日消息,针对火币近日传出COO朱嘉伟已离职消息,火币表示,针对近期监管动态及火币创始人李林在社交媒体的发言,火币方面向界面新闻确认公告及发言真实性。火币联合创始人杜均在社交媒体上表示火币将聚焦合规业务拓展海外市场。(界面新闻)[2021/10/7 20:10:37]

5.同质性资产/差异性资产

支持ERC20和ERC721Token。

6.可实现多个以太坊侧链

目前,只有一条以太坊侧链实现了Elastos的DPoS共识机制。如果有必要,可以使用不同的共识机制生成多条Elastos以太坊侧链,这在技术上是可行的。

7.可编程

Elastos以太坊侧链是可编程的,这使开发人员可以使用智能合约逻辑来构建新类型的应用程序,其中的应用程序将始终按编程运行。

8.应用程序

支持广泛的应用程序,包括加密货币钱包、金融应用程序、去中心化市场、游戏等。

9.灵活的共识

Elastos以太坊侧链使用DPoS共识机制。以太坊区块链使用ProofofWork(PoW),目前正在切换到ProofofStake(PoS)。

10.增加可扩展性

支持与以太坊区块链相同的所有开发,但具有更高的安全性和更好的可扩展性。

11.智能合约

允许在合同版本小于或等于0.5.1(截至2019年9月)的情况下,以多种编程语言编写智能合约,只要它们可以被编译成EVM(以太坊虚拟机)的“字节码”。

以太坊区块链的相关应用:数字钱包:Metamask,Status,uPort,Brave,CoinbaseWallet,Opera,Balance,EthereumNameService,Civic,SelfKey,BurnerWallet,MyEtherWallet,Alethio用于投资、存储和交易数字货币的去中心化交易所:IDEX,0x,Loopring,Synthetix,Set,Uniswap,Melonport,MakerDAO,Bancor,ForkDelta,AirSwap,LocalEthereum平台和市场:Augur,Golem,Ujo,Aragon,sis,RARE,imbrex,AdChain,t0x,OpenSea,Origin,Auctionity,Tokit,EnjinCoin,Veil,Etherisc,NexusMutual,iXledger去中心化融资:MakerDAOCollateralizedDebtPosition,CompoundFinance,Dharma,Marble,BlockFi,Lendoit,ETHlend,InstaDApp,Settle打赏工作:Gitcoin,BountiesNetwork,Ethlance,Numerai,OpenLaw社交网络:Minds,Peepeth,Akasha,Numa,Indorse,Cent,Livepeer,Refereum,VouchForMe游戏:CryptoKitties,Etheremon,GodsUnchained,FunFair,Etheroll,ETH.TOWN,ChibiFighters,0xUniverse,Lordless,MoonCryptoPolis,CryptoRome,AxieInfinity,HyperDragons,MyCryptoHeroes,MLBChampions,MarbleCards,Mintable,ZED参考来源:https://media.consensys.net/40-ethereum-apps-you-can-use-right-now-d643333769f7

什么是智能合约?

在以太坊的语境中,智能合约不是法律合同。从技术上讲,术语“智能合约”是用来描述一个不可变的计算机程序,它作为以太坊网络协议的一部分,在以太坊虚拟机中确定性地运行。智能合约是完全按照程序运行的计算机程序,没有任何审查或第三方干预。智能合约可以比作在满足特定条件时自动执行某些预定操作的自主运行的代码。

术语“智能合约”本身并不新鲜,早在20世纪90年代,著名密码专家NickSzabo就创造了这个术语,用来描述“一组以数字形式履行指定的承诺,包括各方履行其他承诺的协议”。所有区块链平台都有处理代码的能力。比特币以去中心化的方式处理代码,方便双方进行支付。而在以太坊上,开发人员通过Solidity编写智能合约,创建可执行更多功能的自定义应用程序。

北京今年将投资建设30项应用场景 聚焦区块链等领域新技术应用:7月30日,北京市政府召开新闻发布会,对新场景行动方案重点任务进行解读,并向社会发布第二批30项应用场景建设项目。北京市科委副主任刘晖透露第二批30项应用场景建设项目总投资额52.9亿元,主要聚焦产业升级、城市管理、民生服务等重点领域,以及“三城一区”、城市副中心、新首钢等重点区域。刘晖表示,北京市将以数字化赋能经济发展和培育优化新经济生态,即以场景驱动数字经济技术创新、场景创新与新型基础设施建设深度融合为引领,聚焦人工智能、5G、物联网、大数据、区块链、生命科学、新材料等领域新技术应用,积极推广新业态新模式。(21财经)[2020/7/30]

智能合约的特征:去中心化,存储,代码即法律,默认的备份,避免手工的错误执行,去信任执行、自动执行。

一旦智能合约被部署到以太坊区块链或Elastos以太坊侧链,其代码就不能更改。因此,使用智能合约构建的应用程序非常透明、安全,并且不受审查。修改智能合约的唯一方法是部署一个新合约。智能合约是确定性的,这意味着无论执行哪种智能合约,对于给定的一组交易,结果始终是相同的。

智能合约的工作原理

智能合约本身无法运行,因为代码需要虚拟机或底层操作系统才能理解代码的含义。因此,智能合约首先以Solidity编写。然后,将这些智能合约编译为执行智能合约的以太坊虚拟机可以理解的低级字节码。以太坊区块链和以太坊侧链上的每个节点都包含一个EVM,因此每当部署一个新的智能合约时,以太坊网络中的每个节点都会执行它。

需要注意的是,Solidity并不是唯一可以用来为以太坊平台编写智能合约的编程语言。支持多种高级编程语言,包括:Bamboo:一种受Erlang影响的语言,具有明确的状态转换且没有迭代流(循环)。旨在减少副作用。Solidity:一种语法类似于Javascript、C++和Java的语言。这是以太坊智能合约中最流行和最常用的语言。Serpent:一种与Python语法相似的编程语言。它还可以用来编写功能代码,但是它有时会有副作用。Vyper:一种类似于Serpent的语言,与Serpent相比,它旨在更接近纯功能的,其语法类似于Python。LLL:一种功能编程语言,其语法类似于Lisp。在Solidity成为主流之前,它是以太坊智能合约的第一种高级语言,但是通常很少使用。

以太坊虚拟机

众所周知,以太坊的核心创新是虚拟机(EVM),这也是以太坊智能合约的运行环境。在更专业的术语中,EVM是一个256位的寄存器堆栈,它完全按照预期运行相同的代码。智能合约是不能简单地在任何机器或操作系统上运行的计算机程序,它们需要一个能够理解代码意图的专门平台。与其他虚拟机非常相似,EVM在智能合约代码和执行机器之间创建了一个抽象的计算机。因此,只要用户在他或她的计算机上运行以太坊节点,该节点包括EVM,以便运行以Solidity(或支持的任何可用编程语言)编写的智能合约。但是,EVM本身并不理解以Solidity编写的代码,必须首先将智能合约编译为EVM能够理解的低级字节码(即称为操作代码的机器指令)。然后,EVM根据给定的一组指令或操作代码执行特定的任务。

EVM如何执行Solidity编写的代码

以太坊虚拟机可以比作准图灵完备机。它不是100%图灵完成的,因为EVM执行的计算受Gas限制,Gas可以作为可执行计算数量的上限。在一个完全图灵完备的机器中没有限制;图灵完备是指在给定足够的时间和内存的情况下可以执行任何可能的计算的系统。这就是EVM可以被认为是准图灵完备机的原因,因为它确实有必须遵守的界限。

EVM使以太坊得以被成千上万的开发人员广泛采用,因为它使得编写许多不同类型的程序和使用区块链技术执行它们变得很容易,这反过来又使程序更加安全和去中心化。通过这种机制,许多中心化的服务可以使用智能合约进行去中心化。

智能合约的生命周期以及EVM的执行方式

以下是EVM的工作原理:1.开发人员使用Solidity来编写智能合约。2.智能合约被编译成称为字节码的低级机器指令。字节码用于存储EVM可以理解的操作代码,因为它占用的空间更少,从而提高了效率。在撰写文本时,有超过140个独特的操作代码,这些操作代码使得EVM能够执行以Solidity编写的智能合约代码。有堆栈操作代码、算术操作代码、比较操作代码、环境操作代码、与程序计数器相关的操作代码等等。3.然后,EVM将字节码分成字节并开始执行操作代码。EVM有一个设计局限性,因为它源于256位寄存器堆栈,从中只能一次访问或操作最近的16个项目。由于这种限制,复杂的操作代码使用合约内存来检索或传递数据。内存并不是持久的,所以当智能合约完成执行时,内存内容不会被保存。因此,智能合约使用合约存储来无限期地存储数据。4.合约存储类似于一个公共数据库,可以从外部读取其中的值,而不必向合约发送事务,因此不会产生任何费用。但是,写入存储代价非常昂贵,大约是写入内存的6000倍。5.所有合约代码执行都由以太坊上的每个节点运行。因此,为了避免攻击者试图通过创建执行起来很昂贵的合约来降低网络速度的情况,每个操作代码的执行成本都很高,有些操作代码甚至会收取动态的Gas费用,因此对于所有140多个可用的操作代码来说,Gas费用是不一样的。这就是为什么执行大量的智能合约是非常昂贵的,因为每个智能合约可能使用许多不同的操作代码,而每个操作代码都需要花费大量的执行成本。6.因此,存储在以太坊区块链上的实际上是操作代码,而不是智能合约。并且,根据操作代码的设计目的,以太坊网络每个节点上的EVM都参与执行。

贵州清镇市提出“三个聚焦”,有效推动区块链技术应用:5月20日消息,贵州省清镇市将围绕不断深化大数据、区块链等新技术的应用,聚集农村产业革命、医疗健康领域、县域社会治理,加快推动“六位一体”诚信体系建设,提升县域社会治理能力和水平,助推经济高质量发展。

清镇市提出了“三个聚焦”,有效推动区块链技术应用。即:聚焦农村产业革命,充分运用区块链技术,建好用好综合服务平台,实现产销更加精准对接,助推按时高质量打赢脱贫攻坚战。聚焦医疗健康领域,利用区块链技术打通医院HIS及公共卫生数据系统,打造“智慧医疗”体系。聚焦县域社会治理,推动大数据、区块链等新技术在全省县域社会治理现代化试点中的应用,打造“数字治理”的样板区,不断提升县域社会治理水平,助推平安清镇建设。(新华网)[2020/5/20]

EVM体系结构

在以太坊区块链上运行的EVM存在几个潜在的问题,而Elastos以太坊侧链是专门为解决这些问题而设计的。首先,以太坊区块链上有成千上万个节点,每次部署智能合约时,这成千上万个节点中的每一个都要参与执行,很明显这样效率非常低。另一方面,Elastos以太坊侧链采用了DPoS共识,其中36个超级节点在任何时间点都参与了共识,这是一个更高效的模型。要了解DPoS超级节点,请参阅:《聚焦系列3:亦来云的混合共识机制》

EVM在以太坊区块链上运行的另一个问题与Gas成本有关。如果有大量的智能合约被部署到网络上,矿工就会开始增加执行哪怕是非常简单的智能合约的Gas成本。因此,Gas价格大幅上涨。这一点尤其重要,因为这正是游戏Cryptokitties部署到以太坊区块链期间发生的事情。Cryptokitties拥有超过27,000名注册用户,以太坊网络的使用率上升至25%以上。结果,以太坊网络很难跟上猫的数量,而Cryptokitties交易需要更高的Gas才能及时执行。反过来,以太坊网络上的所有交易的Gas费用都上涨了,这对以太坊的所有用户都产生了负面影响,即使是那些没有参与Cryptokitties的用户。

在Elastos以太坊侧链上,Gas成本是以太坊区块链的很一小部分。其次,没有数千个节点验证以太坊侧链的块。而是有36个超级节点,因为Elastos对侧链采用DPoS共识。第三,如果像Cryptokitties这样的著名游戏被部署在Elastos以太坊侧链上,这些区块将正常生产,而不会显著提高Gas费用。然而,正如《聚焦系列2:亦来云侧链和可扩展性解决方案》中所提到的,“在未来,如果有一天一个以太坊DApp突然流行起来,并接收大量用户、数据和交易,那么一条以太坊侧链可能是不够的。在这种情况下,可以创建一条额外的以太坊侧链,并将大量流量的DApp放在该侧链上。这个过程可以重复多次迭代,以支持几乎无限的DApp。届时,我们可能会看到不是一个,也不是两个,而是五个以太坊侧链在Elastos的基础设施上同时运行。这就是Elastos构建的可扩展性的优势。

Elastos以太坊侧链是如何工作的?

Elastos以太坊侧链是一个基于交易的状态机。状态机读取一系列输入并根据结果转换到新状态。以太坊上的状态是一个区块,这意味着每个新块都依赖于前一个块的状态。前一个块的哈希存储为当前块的一部分,这使得区块链不可变且几乎不可能被篡改。Elastos以太坊侧链由账户、状态、Gas和费用、交易、区块和Tokenomics组成。下面我们将一一介绍。

账户

以太坊网络(不管是在以太坊区块链还是Elastos以太坊侧链上)始终跟踪一个全局状态:世界状态。这种状态由许多称为账户的彼此交互的小节点组成。每个账户都有一个状态和一个20字节的地址。以太坊有两种账户:

外部拥有的账户(普通账户):这些是用户在以太坊上创建的账户,用于相互进行交易,并由私有密钥控制。任何时候,用户在支持以太坊的在线加密货币钱包上创建以太坊地址时,都将创建以下类型的账户。当用户A向用户B发送ETH或ELA时,他们是在两个正常账户之间进行交易。

合约账户:这些账户由智能合约代码控制。代码执行可能有来自普通账户的事务或从其他智能合约接收的调用触发,合约账户具有与之关联的特定逻辑。例如,可以将合约账户设计为在超过每日限额后需要多个签名。通常,普通账户会发送一笔交易以激活合约账户代码,从而允许它执行各种操作。合约账户有两种类型:简单账户和多签账户。

声音 | 全国政协委员江尔雄:聚焦区块链等新经济领域 推动青年大陆就业创业新形势:据大公网消息,台籍全国政协委员、福建省台联会长江尔雄表示,新经济已成为台青西进就业创业热门业态。江尔雄介绍,为落实推动青年来大陆就业创业的新形势新要求,福建台联精准分类、细分领域,聚焦电子商务、大数据、区块链、人工智能和共享经济等台青感兴趣的新经济领域,通过举办系列活动,搭建交流、培训和实习平台,助台青搭上大陆新经济领域就业创业“快车”。[2019/3/7]

两种类型的以太坊账户

需要注意的是,普通账户不需要任何创建成本,而合约账户需要。合约账户受代码的约束,不能自己发起新的交易。对于智能合约而言,代码就是法律,因为每个智能合约都有自己的以太坊账户。

智能合约不能单独启动

状态

在Elastos主链上,主链“状态”由未使用的事务输出(UTXOs)表示。通过创建一个事务并添加一个或多个UTXOs作为事务的输入,当用户花费一个或多个UTXOs时,ELA从一个用户转移到另一个用户。这里举一个简单的例子:如果用户的钱包里有1ELA,想发送0.8ELA给用户B,此时用户A不能简单地发送0.8ELA给用户B。相反,用户需要给自己0.2ELA改变相同的事务的一部分。如果用户A不这样做,则需要向联合挖矿的矿工支付0.2ELA。通常,普通用户不必担心自己会执行所有这些操作,因为钱包会自动设置为执行这些操作。此外,Elastos主链不维护用户账户余额。相反,ELA主链Token持有者在任何给定时间点持有一个或多个UTXOs的私有密钥。钱包负责所有的后台事务,因此普通用户看不到。当用户查看ELA钱包中的余额时,它实际上是持有相应私钥的每个UTXO的总和。

基于UTXO的区块链如何工作

以太坊区块链以及Elastos以太坊侧链,不使用UTXO模型。他们使用“以太坊世界状态”,能够管理所有账户余额。创世区块是以太坊的第一种状态。已进行的每笔交易,已部署的每份智能合约以及已执行的每项挖矿操作都已将全局状态从一种状态更改为另一种状态。全局状态实质上是账户地址和账户状态之间的映射,该映射存储在称为MerklePatricia树的数据结构中。默克尔树使以太坊能够在一个全局状态下有效地存储所有信息。Merkle树中的哈希向上传播,这意味着如果有用户作恶,试图将伪造交易交换到Merkle树的底部,则上述节点的哈希将发生变化,同样,该节点上方的哈希也将发生变化,直到树的根节点受到影响。以太坊块包含状态和交易的根哈希,因此该结构在密码上是安全的,它用于安全地识别以太坊网络上的所有数据。

账户状态包含有关特定以太坊账户的信息,该信息存储一个账户拥有多少ETHELA以及每个账户发送的交易数量。每个账户状态都包含以下字段:随机数,余额,StorageRoot和CodeHash。对于普通账户,CodeHash将为空,而对于合约账户,CodeHash将包含该账户的EVM代码的哈希。该字段是不可变的,这意味着如果部署了错误的智能合约,则以后无法在智能合约代码中对其进行修改。而是必须使用更新的代码部署新的智能合约。从这一点开始,区块链上将永远存在同一智能合约的两个版本:一个是错误的,一个是安全的。

部署后的智能合约将永远保留在区块链上。要修改智能合约代码,必须部署新的智能合约,并且必须将相关应用程序定向到新的智能合约才能生效。

Gas费

在以太坊网络上执行的每一次计算都需要付费,没有免费的东西。在以太坊侧链上向另一位用户发送付款会产生费用,部署和执行智能合约也是如此。该费用以所谓的“Gas”支付。Gas本身并不是代币,而是一种用于计量特定计算所需费用的单位。Gas价格决定了用户愿意花多少钱进行特定交易,并以ETHELA计量。每笔交易都有Gas限额和与之相关的Gas价格。Gas价格和Gas限额的乘积代表发送方愿意为执行交易支付的最大ETHELA金额。举个例子:最高交易费用计算。

0.008ELA的金额是用户愿意在给定交易中花费的最大值。因此,如果交易成本降低,则会退还用户剩余的金额。但是,如果交易成本更高,则该交易被视为无效,因为以太坊网络节点尝试执行交易,但在完成交易之前就用光了Gas。因此,使用过的Gas已经用完,无法退还给用户。在Elastos以太坊侧链上,每个计算都由DPoS超级节点执行,并且每个节点都使用自己的计算机资源来运行这些计算。因此,该费用将发送给超级节点所有者。

中远海运集团董事长许立荣:当前物流业发展理念聚焦于区块链等新技术新载体 : 中远海运集团董事长许立荣在4月9日举行的博鳌亚洲论坛2018年年会“物流的变革”分论坛上表示,当前物流业的发展理念突出地体现为“两个聚焦”:一个是创新理念不再聚焦于传统要素,而是“聚焦”于区块链、新能源、航运电商等新技术、新载体。另一个是服务理念不再聚焦于单一要素、自有要素,而是“聚焦”于一站式、集成化、全程服务。纵向整合、跨界合作、集群竞争正在成为业界共识。[2018/4/10]

在以上场景中,我们讨论了计算,因此所需的数据计算功能都保存在内存中。一旦计算完成,数据将永远丢失,因为它将不再存储在内存中。用户还可以选择将一些数据保存在存储中,也就是说,数据将存储在以太坊侧链状态数据库中。在这里Gas也用于支付存储费用。由于状态数据库上的数据必须存储在所有以太坊节点上,因此用户和开发人员通常都不想保存大量数据,因为这会变得非常昂贵。为了存储更多数据,鼓励开发人员使用其他Elastos服务,例如Hive,该服务在存储大量数据方面具有成本效益,并且是去中心化的。以太坊虚拟机上的计算步骤本质上是昂贵的,因为智能合约的每个操作都需要在以太坊侧链网络的每个节点上执行。因此,以太坊区块链和Elastos以太坊侧链被设计为运行非常简单的逻辑,并且不用于诸如文件存储和机器学习之类的复杂计算,因为这类复杂的计算给网络带来了巨大压力。即使Elastos将以太坊作为侧链之一运行,运行复杂任务的成本仍然过高。从理论上讲,如果只有一个DApp在以太坊侧链上运行,则它可能能够执行一些复杂的计算,然而以太坊侧链由其他DApp共享。但是即使在这种理想化的侧链结构中,以太坊侧链仍然是一个区块链,不应该用于所有事物。未来,以太坊侧链可能会出现另一个侧链,该侧链可以成为允许大量计算的Elastos区块链平台的一部分。对于复杂的任务,可以与ElastosHive,ElastosCarrier以及运行应用程序的物理设备一起执行以太坊侧链服务。这样,繁重的计算将在设备本身上执行,而不是在以太坊侧链上执行,以太坊侧链仅用于运行简单的业务逻辑和智能合约,这些合约是根据外部源的某些操作触发的。

交易次数

无论是从一个人向另一个人发送ETH或ELA,还是部署智能合约,在Elastos以太坊侧链上执行的每个操作都是某种交易。在触发合约定义的某些条件之前,无法自主执行智能合约。如果智能合约通过所谓的“内部交易”存在于以太坊的全球节点范围内,那么它们之间也可以相互通信。智能合约可以相互发送消息并以此方式进行通信。这种交换与常规交易的功能非常相似。但是,它们不是由普通账户生成的,它们必须由合约账户生成。由于普通账户没有向智能合约发送消息,因此没有合约决定的Gas限额。相反,Gas限额已经是智能合约部署的一部分,最初由普通用户设置。此机制在部署智能合约时引入了另一个警告:部署智能合约的用户需要将其智能合约的Gas限额设置为足够的水平,以便该合约可以在必要时向另一个合约发送消息。如果在向其他智能合约地址发送消息时智能合约地址用完了该Gas,则该消息将无效并且不会发送。

区块

一个区块包含一组交易,并且一组区块以链的形式链接在一起,因此被称为“区块链”。

Tokenomics

以太坊区块链和Elastos以太坊侧链之间的主要区别之一是它们使用的币种不同。以太坊区块链使用ETH,而Elastos以太坊侧链使用ETHELA。在以太坊侧链的创世区块中,侧链包含0ETHELA。这是因为在Elastos区块链平台上,整个生态系统都使用相同的基础货币ELA。ELA用于Elastos主链,DID侧链,Token侧链以及以太坊侧链。因此,要使用以太坊侧链,用户必须首先将ELA从主链转移到以太坊侧链地址。然后,他或她可以开始使用以太坊侧链将ETHELA发送给其他用户或执行智能合约。

为了使用以太坊侧链服务,用户必须首先将ELA从主链转移到以太坊侧链地址。

需要注意的是,在以太坊侧链上使用ELA,以太坊侧链的等待时间为15秒,而主链的等待时间为2分钟。这意味着用户无需等待2分钟即可将交易添加到以太坊侧链区块。此过程依赖于DPoS超级节点的共识,这就是为什么要向其他用户发送ETHELA的用户只需等待15秒,智能合约执行也是如此。但是,当用户要将ELA从主链转移到ETH侧链时,理论上所需的总时间约为2分20秒:主链冻结时间为2分钟,ETH为15秒侧链等待时间,以及5秒用于仲裁程序验证的时间。但是实际上,所需的总时间为12分钟,因为如果不等待6个块来处理,则会在回滚时出现问题。当主链上的事务需要执行回滚时,已发送到侧链的事务也需要回滚。从侧链到主链的反向交易也是如此:如果侧链上的交易需要回滚,则主链也需要按顺序回滚。考虑到这种可能性可能会变得非常复杂,并且由于Elastos具有许多侧链,这种回滚可能几乎无法管理。因此,在主链和以太坊侧链之间转移ELA的实际总时间大约需要12分钟。

从以太坊侧链发送ETHELA到Elastos主链

如果用户想要将ETHELA转换为其他区块链中的Token,则他或她首先必须将ETHELA从以太坊侧链转移到Elastos主链;只有这样,他或她才能将这些ELA转移到Elastos生态系统之外。通过这种机制,以太坊侧链被比特币的哈希算力有效地保护。尽管ELA可以在任意侧链中以较短的区块时间自由循环,但必须先返回主链,然后才能转移到Elastos区块链之外。由于此过程中的最终交易始终在主链上进行,因此Elastos主链的安全性将递归地传递给所有侧链,而与它们的共识机制无关,无论是PoW,DPoS,BFT还是其他形式。

智能合约和去中心化应用程序之间的差异

重申一下,智能合约是一段代码,可以保证产生相同的结果,而与运行它的人无关。在以太坊上,智能合约以Solidity编写,并被编译成由一组操作代码组成的字节码。以太坊虚拟机可以理解这些操作代码,并且无论哪个节点运行一段具有给定参数的智能合约代码,智能合约都将始终产生相同的结果。但是EVM不是可以执行任何逻辑的通用虚拟机,因为它只能运行有限数量的操作代码。因此,尽管智能合约的诞生使将区块链技术用于各种目的变得更加容易,但仅智能合约并不能支持完全去中心化的基础设施。智能合约本身是去中心化的,一旦部署它们就没有实体可以控制它们,区块链本身也是去中心化的,但是个人无法构建仅由智能合约组成的完整网站或复杂的应用程序。

举个例子:一个开发人员想要创建一个预测天气预报的网站或应用程序。当预测正确时,开发者的朋友就必须付钱。当预测错误时,开发者就必须付钱给朋友。这看起来像是一个简单的应用程序。实际上,确实如此。然而,为了实现这个场景的目的使用智能合约很重要,这样可以保证开发人员和朋友都不会作弊。对于应用程序来说,具有访问当前天气数据的能力也很重要,以便智能合约可以确定预测是否准确。该应用程序还需要某种逻辑,可以将一个帐户中的资金转移到另一个帐户中,等待结果。开发人员可以执行以下操作:使用以太坊侧链创建单独的以太坊钱包,并购买一些ETHELA。这可以使用以太坊API在应用程序中轻松编码,并且很安全,因为区块链直接用于创建这些钱包。

从这里开始,开发变得更加复杂,因为一旦做出天气预报,应用程序必须从某处获取真实的天气数据。在这里,它必须依靠第三方来访问天气数据,并且这个过程不再去中心。即使此数据检索过程可以去中心化进行,下一个步骤是通过应用程序预测明天的天气,这意味着应用程序必须将此预测保存在某个地方。将数据保存在区块链上非常昂贵,因此存储预测数据需要访问外部数据库,而该数据库当然不会是去中心化的。然后,第二天到来,根据天气预报的准确性执行智能合约。如前所述,由于区块链在自己的网络上运行,因此智能合约不能简单地自己执行,也不能直接与外部资源进行交互。因此,智能合约必须使用Oracle服务与现实世界进行通信。Oracle服务是中心化的,但是即使在去中心化的Oracle服务允许应用程序检索天气数据的情况下,仍然存在更多挑战。

一旦智能合约看到开发者的天气预报并将其与实际天气进行比较,它就会将ETHELA从一个以太坊钱包转移到另一个以太坊钱包,以等待预测的准确性。尽管可以以去中心化的方式执行此操作,但该应用程序仍必须运行并且必须在某个地方运行,因为普通用户不会直接在区块链节点上与区块链进行交互,而是在自己的设备上使用该应用程序,因此该应用程序需要放置在类似于应用程序商店的地方。如果使用iOS,则由AppleStore管理该应用;如果应用程序是网站,则必须将其托管在某个地方。这些模型都不利于去中心化。要指出的是,即使是简单的应用程序也需要比智能合约更多的功能来以去中心的方式运行。仅凭智能合约无法支持成熟的去中心化应用程序,因为它们只是EVM在触发操作时执行的微小逻辑。实际上,这个简单的天气预报应用程序的大多数功能既没有去中心也没有扩展。

了解智能合约和DApp之间的区别也很重要。DApp包含智能合约,但智能合约本身不是DApp。为了让整个应用程序去中心,需要去中心许多不同的部分。不用说区块链行业不存在,世界上根本还不存在。区块链只是难题的一小部分,它不能解决世界上所有的问题,也不能用于编写整个应用程序。虽然以太坊侧链非常适合编写防篡改的智能合约,但还需要利用其他去中心化服务,例如用于身份验证的ElastosDID,用于对等消息传输的ElastosCarrier和用于去中心化存储的ElastosHive。通过结合所有这些固有的去中心化技术,开发人员也许可以创建真正的去中心化应用程序。

Elastos以太坊侧链的共识

Elastos主链与比特币联合挖矿,并具有AuxPoW+DPoS共识。将ELA与BTC联合挖矿的PoW矿工负责打包交易并生产区块,而DPoS超级节点则对区块进行验证和签名。Elastos以太坊侧链使用DPoS共识。因此,以太坊侧链不受主链速度的限制,并且可以在生产区块时独立工作。这是一项主要优势,因为其15秒的等待时间足够快,可以执行现实情况下的大多数事务。最重要的是,现有的以太坊区块链开发人员可以轻松地将以Solidity编写的现有智能合约移植到Elastos以太坊侧链。截至2019年9月,Elastos以太坊侧链尚未采用完整的DPoS共识,因为只能通过Elastos区块链团队管理的白名单程序访问侧链。因此,只有12个CRC超级节点参与生成块并对其进行签名。但是,将来所有36个超级节点都将参与生产区块并对其进行签名,届时,Elastos以太坊侧链将真正去中心化。

截至2019年9月,仅12个CRC超级节点参与了Elastos以太坊侧链的区块生产和验证过程。

将来,所有36个超级节点都将参与Elastos以太坊侧链的区块生产和验证过程。

与所有开发一样,以太坊侧链在这样的早期阶段尚未完全去中心化是至关重要的。如果存在错误,可以尽早发现并有效修复。虽然以太坊侧链上的数据传输过程是去中心化的,但节点的控制尚未去中心化。从部分去中心化的模型开始,然后随着侧链变得更加稳定,逐渐朝着100%去中心化的方向发展,这是Elastos的核心理念,因为Elastos主链在开始时也是一部分去中心化,并且此后随着发展逐步完全去中心化。以太坊侧链将与主链一样经过严格的测试,并且当它充分成熟稳定时,所有36个超级节点都将参与其DPoS共识。

Elastos以太坊侧链如何适应Elastos生态系统?

Elastos以太坊侧链只是Elastos区块链平台许多侧链中的一条,还有主链,DID侧链,Token侧链和NEO侧链。未来,随着Elastos区块链可以水平扩展,以适应更多的需求,以不同的共识容纳更多的侧链,很有可能还会有更多。以太坊侧链提供了一种以Solidity编写的智能合约的方式,其等待时间约为15秒。这些智能合约的目的不是编写整个应用程序,而是用作去中心化关键业务逻辑的工具。对于诸如去中心化ID身份验证之类的东西,可以利用DID侧链。要编写与NEOVM兼容的智能合约,可以使用NEO侧链。要编写用于消息传递,音频交换或视频呼叫的安全的点对点通信系统,可以使用ElastosCarrier。想要以经济高效和去中心化的方式存储任何类型的数据,可以使用ElastosHive。最重要的是,这些服务可以独立运行,也可以共同运行,以生成复杂的,去中心化的应用程序,而这些应用程序是无法单独使用以太坊侧链创建的。

ETHForks,ETH2.0和以太坊区块链的未来

许多人认为,当前的以太坊区块链仍处于起步阶段,因为它既不完全安全也不完全可扩展,并且不能用于构建复杂的,高吞吐量和依赖大数据的应用程序。但是,随着即将到来的重大升级,大量核心基础设施的变化正在进行中。这些变化包括使用支付和状态通道,侧链,等离子,分片等将以太坊区块链过渡到DPoS共识。简而言之,目标是设计一个经过改进的新基础架构,使其更加去中心化,可扩展,安全,简单和可持续。在网上有很多关于以太坊未来路线图的信息。由于这些更改都是通过以太坊2.0实现的,因此Elastos以太坊侧链也可以升级为采用类似功能,这就是开源和去中心化技术的力量。或者,当以太坊2.0稳定时,可能会开发出一个全新的以太坊侧链,称为“以太坊2.0侧链”。Elastos不会与其他项目竞争。相反,它正在通过将成熟的技术集成到其自身的生态系统中来对它们进行补充。这样,基于Elastos的开发人员可以创建复杂的去中心化应用程序,而无需离开Elastos生态系统。

未来可以在Elastos区块链平台上支持以太坊2.0的一种方式。

Elastos以太坊侧链带来了更多可能性的未来

随着我们向开放白名单的合作伙伴和开发人员开放侧链并向公众提供完全访问权限,Elastos以太坊侧链的未来将更加光明。许多项目已经开始将其现有的以太坊区块链项目移植到Elastos以太坊侧链,以集成并利用Elastos提供的整套生态系统服务。请参阅以太坊侧链项目小组的网站,以了解有关以太坊侧链项目小组团队职责的更多信息。如果您满脑创意,请开始使用可部署到Elastos以太坊侧链的智能合约开发DApp。

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

链链资讯

火币APP下载ASTO:去中心化交易协议的特性与缺失

去中心的交易协议往往都在更为分散化与更为便利化方面做权衡,当前在交易量普遍较小的情况下各种协议互有优缺点,而随着新兴交易协议的开发与部署,将有机会在新的创新浪潮中进行资本部署和管理.

[0:31ms0-3:581ms