Passer au contenu principal
Change page

Machine virtuelle Ethereum (EVM)

Dernière modification: @XofEE(opens in a new tab), 13 décembre 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 montrant la composition d'un compte 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.

Diagramme indiquant où le gaz est nécessaire dans les opérations de l'EVM 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 :

Complément d'information

  • Gaz

Cet article vous a été utile ?