如何部署以太坊虚拟机,Fabric如何通过虚拟机部署以太坊智能合约

OKX欧易app

OKX欧易app

欧易交易所app是全球排名第一的虚拟货币交易所,注册领取6万元盲盒礼包!

APP下载   官网注册

如何部署以太坊虚拟机,Fabric如何通过虚拟机部署以太坊智能合约

一、以太坊虚拟机(EVM)是什么

以太坊是一个可编程的区块链。与比特币不同,以太坊并没有给用户提供一组预定义的操作(比如比特币交易),而是允许用户创建他们自己的操作,这些操作可以任意复杂。这样,以太坊成为了多种不同类型去中心化区块链的平台,包括但是不限于密码学货币。

EVM为以太坊虚拟机。以太坊底层通过EVM模块支持智能合约的执行和调用,调用时根据合约的地址获取到代码,生成具体的执行环境,然后将代码载入到EVM虚拟机中运行。通常目前开发智能合约的高级语言为Solidity,在利用solidity实现智能合约逻辑后,通过编译器编译成元数据(字节码)最后发布到以坊上。

EVM架构概述

EVM本质上是一个堆栈机器,它最直接的的功能是执行智能合约,根据官方给出的设计原理,EVM的主要的设计目标为如下几点:

简单性

确定性

空间节省

为区块链服务

安全性保证

便于优化

针对以上几点通过对EVM源代码的阅读来了解其具体的设计思想和工程实用性。

EVM存储系统机器位宽

EVM机器位宽为256位,即32个字节,256位机器字宽不同于我们经常见到主流的64位的机器字宽,这就标明EVM设计上将考虑一套自己的关于操作,数据,逻辑控制的指令编码。目前主流的处理器原生的支持的计算数据类型有:8bits整数,16bits整数,32bits整数,64bits整数。一般情况下宽字节的计算将更加的快一些,因为它可能包含更多的指令被一次性加载到pc寄存器中,同时伴有内存访问次数的减少。目前在X86的架构中8bits的计算并不是完全的支持(除法和乘法),但基本的数学运算大概在几个时钟周期内就能完成,也就是说主流的字节宽度基本上处理器能够原生的支持,那为什么EVM要采用256位的字宽。主要从以下两个方面考虑:

时间,智能合约是否能执行得更快

空间,这样是否整体字节码的大小会有所减少

gas成本

时间上主要体现在执行的效率上,我们以两个整型数相加来对比具体的操作时间消耗。32bits相加的X86

的汇编代码

mov eax, dword [9876ABCD]//将地址9876ABCD中的32位数据放入eax数据寄存器

add eax, dword [1234DCBA]//将1234DCBA地址指向32位数和eax相加,结果保存在eax中

64bits相加的X86汇编代码

mov rax, qword [123456789ABCDEF1]//将地址指向的64位数据放入64位寄存器

add rax, qword [1020304050607080]//计算相加的结果并将结果放入到64位寄存器中

链乔教育在线旗下学硕创新区块链技术工作站是中国教育部学校规划建设发展中心开展的“智慧学习工场2020-学硕创新工作站”唯一获准的“区块链技术专业”试点工作站。专业站立足为学生提供多样化成长路径,推进专业学位研究生产学研结合培养模式改革,构建应用型、复合型人才培养体系。

二、以太坊是什么丨以太坊开发入门指南

以太坊是什么丨以太坊开发入门指南

很多同学已经跃跃欲试投入到区块链开发队伍当中来,可是又感觉无从下手,本文将基于以太坊平台,以通俗的方式介绍以太坊开发中涉及的各晦涩的概念,轻松带大家入门。

以太坊是什么

以太坊(Ethereum)是一个建立在区块链技术之上,去中心化应用平台。它允许任何人在平台中建立和使用通过区块链技术运行的去中心化应用。

对这句话不理解的同学,姑且可以理解为以太坊是区块链里的Android,它是一个开发平台,让我们就可以像基于Android Framework一样基于区块链技术写应用。

在没有以太坊之前,写区块链应用是这样的:拷贝一份比特币代码,然后去改底层代码如加密算法,共识机制,网络协议等等(很多山寨币就是这样,改改就出来一个新币)。

以太坊平台对底层区块链技术进行了封装,让区块链应用开发者可以直接基于以太坊平台进行开发,开发者只要专注于应用本身的开发,从而大大降低了难度。

目前围绕以太坊已经形成了一个较为完善的开发生态圈:有社区的支持,有很多开发框架、工具可以选择。

智能合约

什么是智能合约

以太坊上的程序称之为智能合约,它是代码和数据(状态)的集合。

智能合约可以理解为在区块链上可以自动执行的(由事件驱动的)、以代码形式编写的合同(特殊的交易)。

在比特币脚本中,我们讲到过比特币的交易是可以编程的,但是比特币脚本有很多的限制,能够编写的程序也有限,而以太坊则更加完备(在计算机科学术语中,称它为是“图灵完备的”),让我们就像使用任何高级语言一样来编写几乎可以做任何事情的程序(智能合约)。

智能合约非常适合对信任、安全和持久性要求较高的应用场景,比如:数字货币、数字资产、投票、保险、金融应用、预测市场、产权所有权管理、物联网、点对点交易等等。

目前除数字货币之外,真正落地的应用还不多(就像移动平台刚开始出来一样),相信1到3年内,各种杀手级会慢慢出现。

编程语言:Solidity

智能合约的默认的编程语言是Solidity,文件扩展名以.sol结尾。

Solidity是和JavaScript相似的语言,用它来开发合约并编译成以太坊虚拟机字节代码。

还有长像Python的智能合约开发语言:Serpent,不过建议大家还是使用Solidity。

Browser-Solidity是一个浏览器的Solidity IDE,大家可以点进去看看,以后我们更多文章介绍Solidity这个语言。

运行环境:EVM

EVM(Ethereum Virtual Machine)以太坊虚拟机是以太坊中智能合约的运行环境。

Solidity之于EVM,就像之于跟JVM的关系一样,这样大家就容易理解了。

以太坊虚拟机是一个隔离的环境,在EVM内部运行的代码不能跟外部有联系。

而EVM运行在以太坊节点上,当我们把合约部署到以太坊网络上之后,合约就可以在以太坊网络中运行了。

合约的编译

以太坊虚拟机上运行的是合约的字节码形式,需要我们在部署之前先对合约进行编译,可以选择Browser-Solidity Web IDE或solc编译器。

合约的部署

在以太坊上开发应用时,常常要使用到以太坊客户端(钱包)。平时我们在开发中,一般不接触到客户端或钱包的概念,它是什么呢?

以太坊客户端(钱包)

以太坊客户端,其实我们可以把它理解为一个开发者工具,它提供账户管理、挖矿、转账、智能合约的部署和执行等等功能。

EVM是由以太坊客户端提供的。

Geth是典型的开发以太坊时使用的客户端,基于Go语言开发。 Geth提供了一个交互式命令控制台,通过命令控制台中包含了以太坊的各种功能(API)。Geth的使用我们之后会有文章介绍,这里大家先有个概念。

Geth控制台和Chrome浏览器开发者工具里的面的控制台是类似,不过是跑在终端里。

相对于Geth,Mist则是图形化操作界面的以太坊客户端。

如何部署

智能合约的部署是指把合约字节码发布到区块链上,并使用一个特定的地址来标示这个合约,这个地址称为合约账户。

以太坊中有两类账户:

·外部账户

该类账户被私钥控制(由人控制),没有关联任何代码。

·合约账户

该类账户被它们的合约代码控制且有代码与之关联。

和比特币使用UTXO的设计不一样,以太坊使用更为简单的账户概念。

两类账户对于EVM来说是一样的。

外部账户与合约账户的区别和关系是这样的:一个外部账户可以通过创建和用自己的私钥来对交易进行签名,来发送消息给另一个外部账户或合约账户。

在两个外部账户之间传送消息是价值转移的过程。但从外部账户到合约账户的消息会激活合约账户的代码,允许它执行各种动作(比如转移代币,写入内部存储,挖出一个新代币,执行一些运算,创建一个新的合约等等)。

只有当外部账户发出指令时,合同账户才会执行相应的操作。

合约部署就是将编译好的合约字节码通过外部账号发送交易的形式部署到以太坊区块链上(由实际矿工出块之后,才真正部署成功)。

运行

合约部署之后,当需要调用这个智能合约的方法时只需要向这个合约账户发送消息(交易)即可,通过消息触发后智能合约的代码就会在EVM中执行了。

Gas

和云计算相似,占用区块链的资源(不管是简单的转账交易,还是合约的部署和执行)同样需要付出相应的费用(天下没有免费的午餐对不对!)。

以太坊上用Gas机制来计费,Gas也可以认为是一个工作量单位,智能合约越复杂(计算步骤的数量和类型,占用的内存等),用来完成运行就需要越多Gas。

任何特定的合约所需的运行合约的Gas数量是固定的,由合约的复杂度决定。

而Gas价格由运行合约的人在提交运行合约请求的时候规定,以确定他愿意为这次交易愿意付出的费用:Gas价格(用以太币计价)* Gas数量。

Gas的目的是限制执行交易所需的工作量,同时为执行支付费用。当EVM执行交易时,Gas将按照特定规则被逐渐消耗,无论执行到什么位置,一旦Gas被耗尽,将会触发异常。当前调用帧所做的所有状态修改都将被回滚,如果执行结束还有Gas剩余,这些Gas将被返还给发送账户。

如果没有这个限制,就会有人写出无法停止(如:死循环)的合约来阻塞网络。

因此实际上(把前面的内容串起来),我们需要一个有以太币余额的外部账户,来发起一个交易(普通交易或部署、运行一个合约),运行时,矿工收取相应的工作量费用。

以太坊网络

有些着急的同学要问了,没有以太币,要怎么进行智能合约的开发?可以选择以下方式:

选择以太坊官网测试网络Testnet

测试网络中,我们可以很容易获得免费的以太币,缺点是需要发很长时间初始化节点。

使用私有链

创建自己的以太币私有测试网络,通常也称为私有链,我们可以用它来作为一个测试环境来开发、调试和测试智能合约。

通过上面提到的Geth很容易就可以创建一个属于自己的测试网络,以太币想挖多少挖多少,也免去了同步正式网络的整个区块链数据。

使用开发者网络(模式)

相比私有链,开发者网络(模式)下,会自动分配一个有大量余额的开发者账户给我们使用。

使用模拟环境

另一个创建测试网络的方法是使用testrpc,testrpc是在本地使用内存模拟的一个以太坊环境,对于开发调试来说,更方便快捷。而且testrpc可以在启动时帮我们创建10个存有资金的测试账户。

进行合约开发时,可以在testrpc中测试通过后,再部署到Geth节点中去。

更新:testrpc现在已经并入到Truffle开发框架中,现在名字是Ganache CLI。

Dapp:去中心化的应用程序

以太坊社区把基于智能合约的应用称为去中心化的应用程序(DecentralizedApp)。如果我们把区块链理解为一个不可篡改的数据库,智能合约理解为和数据库打交道的程序,那就很容易理解Dapp了,一个Dapp不单单有智能合约,比如还需要有一个友好的用户界面和其他的东西。

Truffle

Truffle是Dapp开发框架,他可以帮我们处理掉大量无关紧要的小事情,让我们可以迅速开始写代码-编译-部署-测试-打包DApp这个流程。

总结

我们现在来总结一下,以太坊是平台,它让我们方便的使用区块链技术开发去中心化的应用,在这个应用中,使用Solidity来编写和区块链交互的智能合约,合约编写好后之后,我们需要用以太坊客户端用一个有余额的账户去部署及运行合约(使用Truffle框架可以更好的帮助我们做这些事情了)。为了开发方便,我们可以用Geth或testrpc来搭建一个测试网络。

注:本文中为了方便大家理解,对一些概念做了类比,有些严格来不是准确,不过我也认为对于初学者,也没有必要把每一个概念掌握的很细致和准确,学习是一个逐步深入的过程,很多时候我们会发现,过一段后,我们会对同一个东西有不一样的理解。

三、Hyperledger***Fabric如何通过虚拟机部署以太坊智能合约

EVM作为用户链代码安装到Fabric中,通过它部署智能合约。单个EVM链代码能在通道上运行多个以太坊智能合约。链码不采用以太坊的共识方法。所有事务遵循Fabric事务流中的执行、订单、验证步骤。在不同组织中确保足够的对等方安装链代码,并设置一个确保一定程度分散的认可政策。与已部署的智能合约交互需要fab3,它通过以太坊JSON RPC API实现一组有限的API,用作web3提供者。

为了安装EVM链代码,链代码位于evmcc下的repo fabric-chaincode-evm。安装链码通常遵循常规步骤,基于fabric-samples中first-network教程的1.3版。

挂载EVM链代码需要更新docker-compose-cli.yaml,包含fabric-chaincode-evm。

通过运行启动网络,执行docker exec-it cli bash命令。如果成功,应显示提示信息。

更改目标对等方,使用环境变量如CORE_PEER_MSPCONFIGPATH、CORE_PEER_ADDRESS、CORE_PEER_LOCALMSPID和CORE_PEER_TLS_ROOTCERT_FILE。

在所有对等设备上安装EVM链代码,执行peer chaincode install和peer chaincode instantiate命令。

与EVM Chaincode交互,有通用方法:通常的Fabric工具和Web3。

使用Peer CLI,部署合约时,to字段设为零地址,input包含合约编译后的evm字节码。与合约交互,设置值,如使用set(x)函数,将值设置为10,然后使用get()函数验证值是否正确。

使用Web3.js库可以改善部署和管理EVM智能合约的用户体验。它期望实现以太坊JSON RPC API的接口。通过设置Fab代理,实现与Fabric网络的交互。

部署合约时,需要evm字节码和合约的ABI。使用web3部署合约后,设置web3.eth.defaultAccount,与合约进行交互,如设置值或验证值。

综上所述,Hyperledger Fabric通过虚拟机部署以太坊智能合约的方法涉及链代码安装、交互和与合约的部署。在部署和管理过程中,利用Fabric工具和Web3.js库可以有效实现智能合约的管理与交互。

本站所有软件信息均由用户上传发布,版权归原著所有。如有侵权/违规内容,敬请来信告知邮箱:764327034@qq.com,我们将及时撤销! 转载请注明出处:https://czxurui.com/zx/148321.html

打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2024年11月15日
下一篇 2024年11月15日

相关推荐

  • 以太坊怎么提币保存,如何保持你的以太坊的币的安全和保值

    一、火币清退我的币怎么办具体做法如下:1.虽然会清退大陆用户,但是火币用户账户中的比特币、泰达币等加密货币资产,不会有什么风险,更不会清空账户。目前币市还在恐慌情绪笼罩下,前景还不明朗,而且距离年底火币清退用户还有3个月时间。2.如果没有成熟的方案,可以暂时边

    2024-11-15 22:30:02
    2 0
  • 以太坊钱包 如何使用,以太坊钱包账户怎么登录

    一、怎么注册以太坊钱包申请以太坊钱包官方网站。搜索进入“以太坊钱包官网”,输入密码,然后单击生成钱包;下载并保存密钥文件;您可以选择其他熟悉的方式来访问您的钱包。你的钱包完全生成好了,别人可以给你发送以太坊,或者你也可以给别人发送以太坊了。必须记住申请过程

    2024-11-15 19:00:01
    2 0
  • 以太坊有哪些交易平台,目前比较好的数字货币交易所都有哪些能具体说说吗

    一、去中心化交易所平台币有哪些与传统交易所区别在于撮合方式不同,去中心化交易所用的是智能合约,而中心化交易所用的是交易所撮合算法,带币币互换的钱包其实是去中心化交易所的雏形,现在很多钱包也转型做去中心化交易所。去中心化交易所平台有:1、Uniswap;2、MDEX;3、

    2024-11-15 16:00:01
    2 0
  • 以太智能币如何挖,以太坊如何挖矿

    一、以太坊币是如何产生的以太坊币是如何产生的?随着人们对区块链技术和加密货币的认知度逐渐提高,以太坊币成为现在最热门的加密货币之一。但是,许多人都不清楚以太坊币是如何产生的。在本文中,我们将探讨以太坊币的产生过程。以太坊是一种基于区块链的开源平台,用于构建

    2024-11-15 15:00:01
    3 0
  • 以太坊怎么涨得快,以太坊为什么会涨

    一、以太坊为什么会涨以太坊涨价的原因主要有以下几点:一、技术优势和智能合约的广泛应用。以太坊作为领先的智能合约平台,其技术优势和生态系统吸引了大量开发者与用户。随着去中心化金融等应用的兴起,以太坊的需求和市值不断增长。二、区块链技术的普及和应用场景扩大。区

    2024-11-15 14:00:02
    3 0
  • 以太经典怎么样,以太坊和以太经典的区别

    一、etc以太经典值得长期持有吗1.以太经典是否可以长期持有还要看它后期的表现。ETC是以太坊分叉币,也是大家近期大家口中的末日战车,总量只有1亿,目前的市值第十八名,类属主流价值币种。目前的价格已上涨到44美元左右,伴随着不断试探1万压力位的行情,牛市来的时候应该还

    2024-11-15 09:00:01
    3 0

发表回复

8206
验证码

评论列表(0条)

    暂无评论

ok交易所
已有100万用户加入ok交易所

立即下载