この記事では、Python Ethereum 仮想マシンでの Py-EVM の実装について紹介します。これには一定の参考価値があります。必要な友人は参照できます。お役に立てれば幸いです。
Py-EVM は、Python で書かれた Ethereum 仮想マシンの新しい実装です。現在、github には 695 個のスターがあり、活発に開発中ですが、Ethereum/test が提供するテスト スイートを通じて急速に進歩しています。多くの設計上の決定が PyEthereum コードベースからインスピレーションを受け、さらには直接移植されたため、Vitalik と既存の PyEthereum コードが急速に進歩したことに感謝しています。
Py-EVM は、最終的には EVM の事実上の Python 実装となることを目指しており、パブリック チェーンとプライベート チェーンに幅広いユースケースを提供します。開発は、完全に機能するメインネット ノードとして実行できる、明確に定義された API、フレンドリーでわかりやすいドキュメントを備えた EVM の作成に重点を置きます。
特に Py-EVM の目的は次のとおりです。
最も広く使用され理解されている言語の 1 つである Python での EVM の実装例を提供します。
フル ノードまたは軽量ノードを構築するための低レベル API を顧客に提供します。
理解と変更が簡単です。
研究だけでなく、プライベート ブロックチェーンなどの代替ユースケースもサポートする高い柔軟性。
Py-EVM は EVM の低レベル API を提供しますが、フル ノードやライト ノードを直接実装するように設計されていません。
Py-EVM に基づいて、Trinity と呼ばれる完全なノードの基本実装を提供します。
将来的には、Py-EVM に基づく代替クライアントが登場する可能性があります。
ステップ 1: アルファ リリース
計画は、テスト目的に適した MVP、アルファ レベルのリリースから始まります。私たちは、一般的なフィードバックやバグ発見だけでなく、アーキテクチャや API の選択に関するフィードバックを提供してくれる早期採用者を探しています。
Py-EVM はすべてのクライアントに共通のテスト サブモジュールに依存しているため、--recursive フラグを使用してリポジトリのクローンを作成する必要があります。例:
git clone --recursive git@github.com:ethereum/py-evm.git
Py-EVM には Python 3 が必要です。一般に、クリーンな Python 3 環境を保証する最善の方法は、virtualenv を使用することです。例:
# once: $ virtualenv -p python3 venv # each session: $ . venv/bin/activate
次に、次の方法で必要な Python パッケージをインストールします:
pip install -e .[dev]
テストは次を使用して実行できます:
pytest
あるいは、tox
をインストールして完全なテスト スイートを実行することもできます。
Pandoc は、マークダウン README を pypi で適切にレンダリングするための正しい形式に変換するために必要です。
Debian 系システムの場合:
apt install pandoc
OSX の場合:
brew install pandoc
新しいバージョンをリリースするには:
bumpversion $$VERSION_PART_TO_BUMP$$ git push && git push --tags make release
新しい Docker イメージを作成するには:
make create-docker-image version=<version>
デフォルトでは、これを指す 2 つのタグを持つ新しいイメージが作成されます:
ethereum/trinity:
ethereum /trinity:最新: (将来の「最新」で上書きされるまでの最新)
次に、Docker Hub にプッシュします。
docker push ethereum/trinity:<version> # the following may be left out if we were pushing a patch for an older version docker push ethereum/trinity:latest
bumpversion の使用方法
このリポジトリのバージョン形式は {major}.{minor} です。{patch} は安定版、{patch}.{minor を意味します。 }. {patch}-{stage}.{devnum} は不安定を意味します (ステージはアルファまたはベータの可能性があります))。
次のバージョンをリリースするには、bumpversion を使用して、調整する部分を指定します (bumpversionminor や、bumpversion devnum など)。
ベータ版を使用している場合は、バンプバージョン段階から安定版に切り替わります。
現在のバージョンが安定しているときに不安定なバージョンを発行するには、新しいバージョンを明示的に指定します。たとえば、bumpversion --new-version 4.0.0-alpha.1 devnum
以上がPython Ethereum 仮想マシンによる Py-EVM の実装の概要の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。