Machine virtuelle Ethereum (EVM)
Dernière modification: @XofEE(opens in a new tab), 21 juin 2024
La machine virtuelle Ethereum (EVM) est un environnement virtuel décentralisé qui exécute le code de manière cohérente et sécurisée sur tous les nœuds Ethereum. Les nœuds exécutent l'EVM qui exécute des contrats intelligents, utilisant du «gaz» pour mesurer l'effort de calcul requis pour les opérations, garantissant une allocation efficace des ressources et la sécurité du réseau.
Prérequis
Une certaine familiarité avec la terminologie commune en informatique, comme les octets(opens in a new tab), la mémoire(opens in a new tab), et une pile(opens in a new tab) sont nécessaires pour comprendre l'EVM. Il peut se révéler utile d'être à l'aise avec les concepts de cryptographie/blockchain comme les fonctions de hachage(opens in a new tab), et l'arbre de Merkle(opens in a new tab).
Du registre à la machine d'état
L'analogie avec un « registre distribué » est souvent utilisée pour décrire les blockchains comme Bitcoin, qui permettent l'existence d'une monnaie décentralisée utilisant des outils de cryptographie fondamentaux. Le registre tient un enregistrement des activités devant se conformer à un ensemble de règles, celles-ci régissant ce que quelqu'un peut, ou ne peut pas faire, pour modifier le registre. Par exemple, une adresse Bitcoin ne peut pas dépenser plus de Bitcoin qu'elle n'en a reçu. Ces règles sont appliquées à toutes les transactions sur Bitcoin et de nombreuses autres blockchains.
Alors qu'Ethereum dispose de sa propre cryptomonnaie native (Ether) qui suit presque exactement les mêmes règles intuitives, il offre également une fonction beaucoup plus puissante : les contrats intelligents. Pour cette fonctionnalité plus complexe, une analogie plus sophistiquée est nécessaire. Au lieu d'un registre distribué, Ethereum est une machine d'état distribuée(opens in a new tab). L'état d'Ethereum est une grande structure de données qui contient non seulement tous les comptes et tous les soldes, mais aussi une machine à état qui peut changer d'un bloc à l'autre selon un ensemble de règles prédéfinies, et qui peut exécuter du code machine arbitraire. Les règles spécifiques de changement d'état d'un bloc à l'autre sont définies par l'EVM.
Schéma adapté à partir du document EVM Ethereum illustrated(opens in a new tab)
Fonction de transition d'état Ethereum
L'EVM se comporte comme une fonction mathématique : avec des données en entrée, elle produit une sortie déterministe. Il est donc très utile de décrire plus formellement Ethereum comme ayant une fonction de transition d'état :
1Y(S, T) = S'
Étant donné un ancien état valide (S)
et un nouvel ensemble de transactions valides (T)
, la fonction de transition d'état Ethereum Y(S, T)
produit un nouvel état de sortie valide S'
État
Dans le contexte d'Ethereum, l'état est une énorme structure de données appelée arbre de Patricia Merkle modifié, qui conserve tous les comptes liés par hachages et réduits à un seul hash racine stocké sur la blockchain.
Transactions
Les transactions sont des instructions signées cryptographiquement provenant des comptes. Il existe deux types de transactions : celles qui donnent lieu à appels de messages et celles qui débouchent sur la création de contrats.
La création d'un contrat entraîne la création d'un nouveau compte de contrat contenant le bytecode du contract intelligent compilé. Chaque fois qu'un autre compte effectue un appel de message à ce contrat, il exécute son bytecode.
Instructions de l'EVM
L'EVM s'exécute comme une machine de pile(opens in a new tab) avec une profondeur de 1 024 éléments. Chaque élément est un mot de 256 bits qui a été choisi pour la facilité d'utilisation avec la cryptographie 256 bits (comme les hachages Keccak-256 ou les signatures secp256k1).
Lors de l'exécution, l'EVM maintient une mémoire transitoire (en tant que tableau d'octets adressé à un mot) qui ne persiste pas entre les transactions.
Cependant, les contrats contiennent un arbre de stockage Merkle Patricia (en tant que tableau de mots adressables à un mot), associé au compte en question et faisant partie de l'état global.
Le bytecode du contract intelligent compilé s'exécute comme un certain nombre de codes d'opérations EVM, qui effectuent des opérations de pile standards comme XOR
, AND
, ADD
, SUB
, etc. L'EVM implémente également un certain nombre d'opérations de pile spécifiques à la blockchain, comme ADDRESS
, BALANCE
, BLOCKHASH
, etc.
Schéma adapté à partir du document EVM Ethereum illustrated(opens in a new tab)
Implémentations de l'EVM
Toutes les implémentations de l'EVM doivent respecter les spécifications décrites dans les pages jaunes Ethereum.
Au cours des neuf années d'existence d'Ethereum, l'EVM a fait l'objet de plusieurs révisions, et il existe plusieurs implémentations de l'EVM dans divers langages de programmation.
Les clients d'exécution Ethereum incluent une implémentation de l'EVM. Il existe également plusieurs implémentations autonomes, telles que :
- 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
Complément d'information
- Les pages jaunes Ethereum(opens in a new tab)
- Jellopaper aka KEVM : Sémantique de l'EVM en K(opens in a new tab)
- Livre beige Ethereum(opens in a new tab)
- Codes d'opérations de l'EVM(opens in a new tab)
- Documents de Référence aux Codes Opératoires de la Machine Virtuelle Ethereum(opens in a new tab)
- Une courte introduction dans la documentation de Solidity(opens in a new tab)
- Maîtriser Ethereum - La Machine Virtuelle Ethereum(opens in a new tab)