Py-EVM是用Python編寫的以太坊虛擬機器的新實現。目前github上695個star,正在積極開發中,但正在通過以太坊/測試提供的測試套件快速推進。我們感謝有Vitalik和現有的PyEthereum程式碼,使得我們有的快速進步,因為許多設計決策都受到啟發,甚至直接從PyEthereum程式碼庫移植。
Py-EVM旨在最終成為EVM的事實Python實現,為公共和私有鏈提供廣泛的用例。開發將側重於建立具有良好定義的API的EVM,友好且易於理解的文件,可作為功能齊全的主網節點執行。
特別是Py-EVM目標旨在:
- 提供是一種使用最廣泛使用和理解的語言之一Python的EVM的示例實現。
- 為客戶提供低階API,以構建完整或輕量級節點。
- 易於理解和修改。
- 高度靈活地支援研究以及私有區塊鏈等替代用例。
Trinity
雖然Py-EVM提供EVM的低階API,但它並不旨在直接實現完整節點或輕節點。
我們提供了一個基於Py-EVM的稱為Trinity的完整節點的基本實現。
將來可能會有基於Py-EVM的替代客戶端。
第1步:Alpha釋出
該計劃首先是適用於測試目的的MVP,alpha級釋出。我們將尋找早期採用者,以提供有關我們的架構和API選擇的反饋,以及一般反饋和錯誤發現。
開發
Py-EVM依賴於所有客戶端的常見測試的子模組,因此你需要使用–recursive標記克隆repo。例如:
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
來執行完整的測試套件。
Releasing
需要Pandoc才能將markdown 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>
預設情況下,這將建立一個新映象,其中有兩個標記指向它:
-
ethereum/trinity:<version>
:(顯示版本) -
ethereum/trinity:latest
:(最新的,直到用未來的“最新”覆蓋)
然後,推送到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
此repo的版本格式為{major}.{minor}.{patch}
表示stable,{patch}.{minor}.{patch}-{stage}.{devnum}
表示unstable(stage可以是alpha或beta))。
要在釋出下一個版本,請使用bumpversion並指定要調整的部分,例如bumpversion minor或bumpversion devnum。
如果你處於beta版,則bumpversion stage階段將切換為穩定版。
要在當前版本穩定時發出不穩定版本,請明確指定新版本,例如bumpversion --new-version 4.0.0-alpha.1 devnum
學習文件:Documentation hosted by ReadTheDocs
======================================================================
分享一個的互動式線上程式設計實戰教程:
python以太坊,主要是針對python工程師使用web3.py進行區塊鏈以太坊開發的詳解。
這裡是原文