当前位置:首页 > 物联网 > 区块链
[导读] 本篇文章我们将接续上篇来介绍区块链2.0 以太坊- Vitalik如何在中本聪设计的比特币架构上进行升级与改动,透过首度揭晓的「以太坊区块链架构图」带大家完整认识以太坊的运作原理! Vi

本篇文章我们将接续上篇来介绍区块链2.0 以太坊- Vitalik如何在中本聪设计的比特币架构上进行升级与改动,透过首度揭晓的「以太坊区块链架构图」带大家完整认识以太坊的运作原理!

Vitalik Buterin 领衔设计的区块链2.0 -以太坊Ethereum

How Ethereum Blockchain Work

以太坊虚拟机(EVM — Ethereum Virtual Machine )

介绍以太坊区块链架构前必须要介绍一下「EVM 」,EVM是以太坊为了让人人都能成为节点而创造的计算引擎。由于每个节点的软硬体环境可能都不一样,为了确保每个节能都能进行一样的运算,于是各个节点都透过EVM 来执行Ethereum 交易的状态转移与智能合约,以确保每一个节点都有相同的执行环境。

前言完毕,紧接着我们便来一探究竟:

以太坊交易的一生

有别于比特币的UTXO,以太坊是采用Account 的架构。

由于以太坊多了智慧合约的设定,将会分成AB C 三个part 来做说明,

我们先从最单纯的Ether 转帐交易开始看起:

A. 单纯的Ether 转帐交易

「 单纯的Ether 转帐交易」示意图

1. 一个使用者(EOA)欲发起一笔交易。

2. 透过钱包(管理私钥的工具)输入交易资讯

To:对方接收地址;

Amount:欲转移的Ether数量;

Gas Price:单位Gas给的手续费;(参阅第5节)

Gas Limit:普通的Ether转移交易都是21,000 Gas,不用动;

Input Data:视是否要在交易中留下文字讯息。

3. 以私钥签署交易。

4. 广播「加上签名的交易封包」至邻近的以太坊节点们。

5. 节点接收到新交易时,会先至State Database 检查交易发起地址是否具有足额Ether(Balance)可做转移,若无则该交易会即刻被丢弃。

6. 若检查后确认有足额,则该交易会被放入到Tx Pool中。

(按照Gas Price设的多寡由高至低排序)

7. 等待出块的同时,各节点会

A.广播接收到的交易

B.接收未在Tx Pool内的交易

8. 矿工节点们(有在用电脑算力找nonce值,拼出块奖励的节点)会捞取手续费较高的交易们,进到EVM运算并更改状态值后,将已完成运算的交易们来打包成新区块(运算中出现错误的交易会被丢弃),随后用电脑算力来计算nonce值。

*注:这边的nonce值跟前面介绍过的以太坊地址的nonce值不同(以太坊有两个nonce:一个是挖矿的;一个是地址的交易序次。)

*注2:运算的同时便会消耗Gas。

9. 成功找到nonce值,出块的矿工会获得出块奖励及该区块所有打包交易给的手续费。

10. 该矿工节点将新的区块广播至全世界的其他节点们。

11. 其他节点同步 《8660586区块高度(最新的区块)》、

《State Database》、《Tx Pool》资料,继续广播与接收新交易。

12. 矿工节点再从Tx Pool 中捞取未出块的交易们运算并打包成新的区块。

以上,便是一笔以太坊交易从发送到出块会经历的流程。紧接着我们来一探究竟智慧合约是如何部署的:

B. 部署智慧合约(Smart Contract)

我们在第2节其实有概略性的介绍过一次,此刻我们搭配示意图更完整地来介绍一遍吧!

「 部署智慧合约」流程示意图

1. 以Remix或其它开发工具撰写完成智慧合约。

2. 将原始码编译为Bytecode。

3. 使用者(EOA)透过钱包(管理私钥的工具)输入交易资讯

To: 0x0

Amount:视是否要将Ether打入合约中

Gas Limit:按照合约繁复程度决定要设多少

Gas Price:视交易状况及欲出块的时间急迫性

Input Data:放入合约Bytecode

4. 以私钥签署交易,广播「加上签名的交易封包」至邻近的以太坊节点们。

5. 节点接收到新交易时,一样会先至State Database 检查交易发起地址是否具有足额Ether(Balance)可做转移(有些情况会把Ether打入合约) ,若无足额则该交易会即刻被丢弃。

6. 若检查后确认有足额,则该交易会被放入到Tx Pool中。

(按照Gas Price设的多寡由高至低排序)

7.等待出块的同时,各节点依旧会

A.广播接收到的交易

B.接收未在Tx Pool内的交易

8. 矿工节点们捞取起本笔合约部署交易,进到EVM运算。

9. 将合约程式码部署至Program Code ROM,是个部署后便不能进行更动的Read-Only Memory(唯独记忆体)。

10.同时,智慧合约亦可以另外使用记忆体(Memory)来储存合约所需要纪录的资讯。例如:一个发行ERC-20 Token的智慧合约,便可以使用记忆体来纪录各个以太坊地址所「持有Token数量」,追踪各个地址的ERC-20 Token Balance。

11. 上方步骤完成后,便会将运算后的结果(合约地址、Gas Used)写回到该笔交易中。

12. 矿工节点们将运算完的交易们打包成新区块(运算中出现错误或Gas给不够的交易会被丢弃),随后用电脑算力来计算nonce值。

13.成功找到nonce值,出块的矿工会获得出块奖励及该区块所有打包交易给的手续费。

14.该矿工节点将新的区块广播至全世界的其他节点们。

15. 其他节点同步 《8660586区块高度(最新的区块)》、

《State Database》、《Tx Pool》、《Contract Code ROM》、

《ERC-20 Token Balance》资料,继续广播与接收新交易。

16. 矿工节点再从Tx Pool 中捞取未出块的交易们运算并打包成新的区块。

以上,便是一笔智慧合约部署的交易从发送到出块会经历的流程。

最后,我们来解析呼叫智慧合约进行操作与互动:

C. 呼叫合约进行互动

这部分我们在第2节与第4节其实也有概略性的介绍过,

此刻我们搭配示意图,更着重在节点的部分,较完整地来介绍一遍吧!

「 呼叫智慧合约」流程示意图

1. 透过DApp 介面或其它方式来呼叫智慧合约进行互动

2. 生成以下形式的交易格式:

To:合约地址

Amount:视是否要将Ether打入合约中

Gas Limit:按操作合约的繁复程度决定要设多少

Gas Price:视交易状况及欲出块的时间急迫性

Input Data:放入以hex型态表示的「要呼叫的合约function与参数」

3. 以私钥签署交易,广播「加上签名的交易封包」至邻近的以太坊节点们。

4. 节点接收到新交易时,一样会先至State Database 检查交易发起地址是否具有足额Ether(Balance)可做转移(如牵涉到) ,若无足额则该交易会即刻被丢弃。

5. 若检查后确认有足额,则该交易会被放入到Tx Pool中。

(按照Gas Price给的多寡由高至低排序)

6. 等待出块的同时,各节点依旧会

A.广播接收到的交易

B.接收未在Tx Pool内的交易

7. 矿工节点们捞取起本笔「合约操作交易」,进到EVM运算。

8. 根据合约地址捞出Program Code ROM 中的合约程式码。

9. 依照MethodID (FuncTIon Hash) 找到合约中对应的FuncTIon。

10. 将相关参数填入进行对应运算。

以ERC-20 Token的Transfer FuncTIon为例,运算时便会更改相关地址的ERC-20 Token Balance。

11. 上方步骤完成后,便会将运算后的结果(新的Token Balance、Gas Used)写回到该笔交易中。

12.矿工节点们将运算完的交易们打包成新区块(运算中出现错误或Gas给不够的交易会被丢弃),随后用电脑算力来计算nonce值。

13. 成功找到nonce值,出块的矿工会获得出块奖励及该区块所有打包交易给的手续费。

14. 该矿工节点将新的区块广播至全世界的其他节点们。

15. 其他节点同步 《8660586区块高度(最新的区块)》、

《State Database》、《Tx Pool》、《ERC-20 Token Balance》等资料,继续广播与接收新交易。

16.矿工节点再从Tx Pool 中捞取未出块的交易们运算并打包成新的区块。

以上,我们便核心地介绍完了以太坊区块链的架构。尽管有许多的技术细节我们此时并未完整交代也未深入着墨,但相信对于初学区块链技术读者来说应该能逐步建立起区块链架构的全貌。
来源: BlockTempo动区动趋 

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

上海2024年4月16日 /美通社/ -- 根据研究和经验, 设备和系统50%的故障或失效可直接或间接地是由转子不平衡引起的。在先前申克现场动平衡仪的基础上, 申克又创新了一套更成熟的移动式平衡设备:SmartBalan...

关键字: BALANCE SMART FFT 振动分析

现如今数字经济完全依赖各大平台的服务,交易能否达成与双方信用直接挂钩。平台往往在交易过程中抽取大量服务费用,导致了交易成本的提高。

关键字: 元宇宙 区块链 虚拟活动

随着人工智能(AI)技术的不断发展和创新,其应用领域也在不断拓展。AI正在逐步渗透到各个行业中,为我们的生活和工作带来诸多变革。本文将为您探讨人工智能在各个领域的应用。

关键字: 人工智能 区块链 应用领域

本文中,小编将对区块链技术予以介绍,如果你想对它的详细情况有所认识,或者想要增进对它的了解程度,不妨请看以下内容哦。

关键字: 区块链 Blockchain

北京2023年9月19日 /美通社/ -- 随着科技的快速发展,我们正处在一个数据爆炸的时代。超大规模数据中心作为数据的重要存储和处理场所,其数量在不断增长,与之而来的数据量也在呈指数级增长。这不仅包括原始数据,还包括分...

关键字: 分布式 节点 软件 数据中心

深圳2023年9月8日 /美通社/ -- 近日,超算领域国际顶级会刊SC23公布了论文入选名单,由微众银行区块链团队发表的论文——《FISCO-BCOS:An Enterprise-grade Permissioned...

关键字: 区块链 OS 开源 联盟链

(全球TMT2023年9月6日讯)耀世星辉新文娱集团控股有限公司宣布,根据2023年8月16日签署的《股份认购协议》,完成发行总计8,064,516 股普通股,认购价格为每股2.48美元,总计2000万美元的战略投资完...

关键字: 云计算 移动互联网 区块链 生态系统

(全球TMT2023年9月5日讯)在2023年华为云沙特峰会上,华为宣布,华为云利雅得节点正式开服。本次开服后,利雅得节点将成为华为云服务中东、中亚和非洲的核心节点。华为云利雅得节点通过3AZ(可用区)架构,提供了高可...

关键字: 节点 华为云 云服务 GO

沙特阿拉伯利雅得2023年9月4日 /美通社/ -- 在2023年华为云沙特峰会上,华为宣布,华为云利雅得节点正式开服,推动该国数字经济增长。 本次开服后,利雅得节点将成为华为云服务中东、中亚和非洲的核心节点,可提供创...

关键字: 华为云 节点 AI 数字化

北京2023年8月31日 /美通社/ -- 与狭义的人工智能相比,通用人工智能通过跨领域、跨学科、跨任务和跨模态的大模型,能够满足更广泛的场景需求、实现更高程度的逻辑理解能力与使用工具能力。2023年,随着 LLM 大规...

关键字: 模型 AI TOKEN GP
关闭
关闭