Py-EVM是用Python编写的以太坊虚拟机的新实现。目前github上695个star,正在积极开发中,但正在经过以太坊/测试提供的测试套件快速推动。咱们感谢有Vitalik和现有的PyEthereum代码,使得咱们有的快速进步,由于许多设计决策都受到启发,甚至直接从PyEthereum代码库移植。python
Py-EVM旨在最终成为EVM的事实Python实现,为公共和私有链提供普遍的用例。开发将侧重于建立具备良好定义的API的EVM,友好且易于理解的文档,可做为功能齐全的主网节点运行。git
特别是Py-EVM目标旨在:github
虽然Py-EVM提供EVM的低级API,但它并不旨在直接实现完整节点或轻节点。web
咱们提供了一个基于Py-EVM的称为Trinity的完整节点的基本实现。docker
未来可能会有基于Py-EVM的替代客户端。编程
第1步:Alpha发布markdown
该计划首先是适用于测试目的的MVP,alpha级发布。咱们将寻找早期采用者,以提供有关咱们的架构和API选择的反馈,以及通常反馈和错误发现。session
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
来运行完整的测试套件。
须要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
此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
======================================================================
分享一些以太坊、EOS、比特币等区块链相关的交互式在线编程实战教程:
python以太坊,主要是针对python工程师使用web3.py进行区块链以太坊开发的详解。
这里是原文