ホームページ > バックエンド開発 > Python チュートリアル > Python Ethereum 仮想マシンによる Py-EVM の実装の概要

Python Ethereum 仮想マシンによる Py-EVM の実装の概要

不言
リリース: 2018-10-18 17:22:39
転載
2665 人が閲覧しました

この記事では、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 を顧客に提供します。

  • 理解と変更が簡単です。

  • 研究だけでなく、プライベート ブロックチェーンなどの代替ユースケースもサポートする高い柔軟性。

Trinity

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]
ログイン後にコピー

Run Tests

テストは次を使用して実行できます:

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 サイトの他の関連記事を参照してください。

ソース:segmentfault.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート