Виртуальная машина Ethereum (EVM)
Последнее редактирование: @omsify(opens in a new tab), 13 декабря 2024 г.
Виртуальная машина Ethereum (EVM) — это децентрализованная виртуальная среда, которая стабильно и безопасно исполняет код на всех узлах Ethereum. Узлы запускают EVM для выполнения смарт-контрактов, используя газ для измерения вычислительных затрат, необходимых для выполнения операций, обеспечивая эффективное распределение ресурсов и безопасность сети.
Прежде чем начать
Некоторые базовые знания в информатике, например термины байт(opens in a new tab), память(opens in a new tab) и стек(opens in a new tab), необходимы для понимания работы EVM. Также было бы полезно ознакомиться с такими понятиями криптографии и блокчейна, как хэш-функции(opens in a new tab) и дерево Меркла(opens in a new tab).
От реестра к машине состояний
Аналогия с «распределенным реестром» часто используется для описания таких блокчейнов, как Биткойн, которые позволяют децентрализовать валюту с использованием фундаментальных инструментов криптографии. Реестр содержит запись о деятельности, которая должна соответствовать набору правил, регулирующих, что кто-то может и не может сделать для изменения реестра. Например, биткойн-адрес не может потратить больше биткойнов, чем получил ранее. Эти правила лежат в основе всех транзакций во многих блокчейнах, включая Биткойн.
Хотя у Ethereum есть собственная криптовалюта (Эфир), которая следует почти точно таким же интуитивным правилам, она также обеспечивает гораздо более мощную функцию: умные контракты. Для этой более сложной функции требуется более сложная аналогия. Вместо распределенного реестра Ethereum представляет собой распределенную машину состояний(opens in a new tab). Состояние Ethereum — это большая структура данных, в которой хранятся не только все счета и балансы, но и состояние машины, которая может изменяться от блока к блоку в соответствии с заранее определенным набором правил и которая может выполнять произвольный машинный код. Конкретные правила изменения состояния от блока к блоку определяются EVM.
Источник адаптированной диаграммы: Ethereum EVM illustrated(opens in a new tab)
Функция перехода состояния Ethereum
EVM ведет себя как математическая функция: при вводе данных производится детерминированный вывод. Поэтому весьма полезно более формально описать Ethereum как имеющий функцию перехода между состояниями:
1Y(S, T)= S'
Учитывая старое допустимое состояние (S)
и новый набор действительных транзакций (T)
, функция перехода состояния Ethereum Y(S, T)
создает новое допустимое состояние вывода S'
Состояние
В контексте Ethereum состояние — это огромная структура данных, называемая модифицированным деревом Меркла вида Patricia, в котором все аккаунты связаны хэшами и сводятся к одному корневому хэшу, хранящемуся в блокчейне.
Транзакции
Транзакции — это криптографически подписанные инструкции от аккаунтов. Есть два типа транзакций: те, которые приводят к вызовам сообщений, и те, которые приводят к созданию контракта.
В результате создания контракта создается новый аккаунт контракта, содержащий скомпилированный байткод умного контракта. Всякий раз, когда другая учетная запись выполняет вызов сообщения для этого контракта, она выполняет свой байткод.
Инструкции EVM
EVM работает как стековая машина(opens in a new tab), вмещающая 1024 элементов. Каждый элемент стека — это 256-битное слово, выбранное для удобства использования в 256-битной криптографии (например, хэши Keccak-256 или подписи secp256k1).
Во время работы EVM использует временную область памяти (в виде байтового массива с адресацией по словам), которая не сохраняется между транзакциями.
Однако контракты содержат хэш-дерево Меркла вида Patricia (в виде массива слов с адресацией по словам), связанное с аккаунтом и рассматриваемое как часть глобального состояния.
Скомпилированный байт-код умного контракта исполняется как последовательность машинных кодов EVM, таких как стандартные машинные операции XOR
, AND
, ADD
, SUB
, и т. д. В стековой машине EVM также есть и специальные блокчейновые опкоды, такие как ADDRESS
, BALANCE
, BLOCKHASH
и т. д.
Источник адаптированных диаграмм: Ethereum EVM illustrated(opens in a new tab)
Реализации EVM
Все реализации EVM должны соответствовать спецификации, описанной в Желтой книге Ethereum.
За девятилетнюю историю Ethereum EVM претерпела несколько пересмотров, и существует несколько реализаций EVM на различных языках программирования.
Клиенты-исполнители Ethereum включают реализацию EVM. Кроме того, существует несколько автономных реализаций, включая:
- 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
Дополнительные ресурсы
- Желтая книга Ethereum(opens in a new tab)
- Jellopaper (или KEVM): семантика EVM в K(opens in a new tab)
- Бежевая книга(opens in a new tab)
- Машинные коды виртуальной машины Ethereum(opens in a new tab)
- Интерактивный справочник по кодам операций виртуальной машины Ethereum(opens in a new tab)
- Краткое введение в документацию по Solidity(opens in a new tab)
- Освоение Ethereum — виртуальная машина Ethereum(opens in a new tab)