Máquina virtual do Ethereum (EVM)
Última edição: @Fritzhoy(opens in a new tab), 13 de dezembro de 2024
A Máquina Virtual Ethereum (EVM, em inglês) é um ambiente virtual descentralizado que executa códigos de forma consistente e segura em todos os nós do Ethereum. Os "nós" executam a EVM para executar contratos inteligentes, usando "gas" para medir o esforço computacional necessário para operações, garantindo a alocação eficiente de recursos e a segurança da rede.
Pré-requisitos
Alguma familiaridade básica com a terminologia comum em ciência da computação, como bytes(opens in a new tab), memória(opens in a new tab) e pilha(opens in a new tab) é necessária para entender a EVM. Também recomendamos se familiarizar com conceitos de criptografia/cadeia de blocos, como funções hash(opens in a new tab) e a árvore Merkle(opens in a new tab).
Do livro-razão para a máquina de estado
A analogia de um 'livro-razão distribuído' é muitas vezes usada para descrever blockchains como o Bitcoin, que permite uma moeda descentralizada usando ferramentas fundamentais de criptografia. O livro-razão mantém um registro de atividades que deve aderir a um conjunto de regras que regem o que alguém pode e não pode fazer para modificar o livro-razão. Por exemplo, um endereço de Bitcoin não pode gastar mais Bitcoin do que o recebido previamente. Essas regras sustentam todas as transações em Bitcoin e em muitas outras blockchains.
Embora Ethereum tenha sua própria criptomoeda nativa (Ether), que segue quase exatamente as mesmas regras intuitivas, ele também permite dispor de uma função muito mais poderosa: os contratos inteligentes. Para este recurso mais complexo, uma analogia mais sofisticada é necessária. Em vez de um livro-razão distribuído, Ethereum é uma máquina de estado distribuída(opens in a new tab). O estado do Ethereum é uma grande estrutura de dados que contém não apenas todas as contas e saldos, mas também um estado da máquina, que pode mudar de bloco para bloco de acordo com um conjunto predefinido de regras, as quais podem executar código de máquina arbitrário. As regras específicas para mudar o estado de bloco em bloco são definidas pela EVM.
Diagrama adaptado do Ethereum EVM ilustrado(opens in a new tab)
A função de transição do estado Ethereum
A EVM se comporta como uma função matemática seria: de acordo com a entrada, ele produz uma saída determinística. Portanto, é bastante útil descrever mais formalmente o Ethereum como tendo uma função de transição de estado:
1Y(S, T)= S'
Dado um antigo estado (S)
e um novo conjunto de transações válidas (T)
, a função de transição de estado de Ethereum Y(S, T)
produz um novo estado de saída válido S'
Estado
No contexto do Ethereum, o estado é uma enorme estrutura de dados chamada árvore de Merkle Patricia modificada, que mantém todas as contas vinculadas por hashes e redutíveis a um único hash raiz armazenado na cadeia de blocos.
Transações
Transações são instruções assinadas criptograficamente de contas. Existem dois tipos de transações: as que resultam em chamadas de mensagem e as que resultam na criação de contratos.
A criação do contrato resulta na criação de uma nova conta de contrato que contém o bytecode compilado do contrato inteligente. Sempre que outra conta faz uma mensagem de chamada a esse contrato, ele executa seu bytecode.
Instruções da EVM
A EVM é executada como uma máquina de pilha(opens in a new tab) com uma profundidade de 1.024 itens. Cada item é uma palavra de 256 bits, que foi escolhida para facilitar o uso com criptografia de 256 bits (como hashes Keccak-256 ou assinaturas secp256k1).
Durante a execução, a EVM mantém uma memória transiente (como um array de bytes direcionado por palavra) que não persiste entre as transações.
Os contratos, no entanto, contêm uma árvore Merkle Patricia de armazenamento (como um array direcionado por palavras) associada com a conta em questão e parte do estado global.
O bytecode compilado do contrato inteligente executa como um número de opcodes de EVM, que realizam operações padrão de stake como XOR
, AND
, ADD
, SUB
etc. A EVM também implementa um número de operações de stake específicas da blockchain, como ADDRESS
, BALANCE
, BLOCKHASH
etc.
Diagrama adaptado do Ethereum EVM ilustrado(opens in a new tab)
Implementações da EVM
Todas as implementações da EVM devem aderir à especificação descrita no Ethereum Yellowpaper.
Durante o histórico de 9 anos do Ethereum, a EVM passou por várias revisões e existem várias implementações da EVM em várias linguagens de programação.
Os clientes de execução Ethereum incluem uma implementação EVM. Além disso, existem várias implementações independentes, incluindo:
- Py-EVM(opens in a new tab) - Python
- evmone(opens in a new tab) - C++
- ethereumjs-vm(opens in a new tab) - JavaScript
- revm(opens in a new tab) - Rust
Leitura adicional
- Ethereum Yellowpaper(opens in a new tab)
- Jellopaper também conhecido como KEVM: semânticos de EVM em K(opens in a new tab)
- O Beigepaper(opens in a new tab)
- Códigos de operação da EVM(opens in a new tab)
- Referência interativa dos códigos de operação da máquina virtual Ethereum(opens in a new tab)
- Uma breve introdução à documentação do Solidy(opens in a new tab)
- Dominando Ethereum - A Máquina Virtual Ethereum(opens in a new tab)