Python 的 Geth 封装库 PyGeth

PyGeth 是一个 Python 封装库,用来做为子进程运行 gethpython

系统依赖

该库须要 geth 可执行文件。linux

安装

pip install py-geth复制代码

快速启动

运行链接到 mainnetgethbash

>>> from geth import LiveGethProcess
>>> geth = LiveGethProcess()
>>> geth.start()复制代码

或者是用于测试的私人本地区块链。这就要求你给他们一个名字。markdown

>>> from geth import DevGethProcess
>>> geth = DevGethProcess('testing')
>>> geth.start()复制代码

默认状况下,DevGethProcessgeth 使用的默认 datadir 设置测试链。若是要更改这些测试链的位置,能够指定替代 base_dir网络

>>> geth = DevGethProcess('testing', '/tmp/some-other-base-dir/')
>>> geth.start()复制代码

每一个实例都有一些方便的属性。函数

>>> geth.data_dir
"~/.ethereum"
>>> geth.rpc_port
8545
>>> geth.ipc_path
"~/.ethereum/geth.ipc"
>>> geth.accounts
['0xd3cda913deb6f67967b99d67acdfa1712c293601']
>>> geth.is_alive
False
>>> geth.is_running
False
>>> geth.is_stopped
False
>>> geth.start()
>>> geth.is_alive
True  # 表示子进程还没有退出
>>> geth.is_running
True  # 表示调用了start(),可是没有stop()
>>> geth.is_stopped
False
>>> geth.stop()
>>> geth.is_alive
False
>>> geth.is_running
False
>>> geth.is_stopped
True复制代码

在测试时,能够很好地查看 geth 进程生成的日志记录输出。py-geth 提供了一个 mixin 类,可用于将 stdoutstderr 输出记录到日志文件中。区块链

>>> from geth import LoggingMixin, DevGethProcess
>>> class MyGeth(LoggingMixin, DevGethProcess):
...     pass
>>> geth = MyGeth()
>>> geth.start()复制代码

全部日志都将写入当前目录./logs/ 中的日志文件。测试

底层 geth 进程可能须要额外的时间来打开 RPC 或 IPC 链接,以及在须要生成 DAG 时开始挖掘。你可使用如下接口来查询这些接口是否已准备就绪。ui

>>> geth.is_rpc_ready
True
>>> geth.wait_for_rpc(timeout=30)  # 等待最多30秒,以便打开RPC链接。
>>> geth.is_ipc_ready
True
>>> geth.wait_for_ipc(timeout=30)  # 等待最多30秒,以便IPC套接字打开。
>>> geth.is_dag_generated
True
>>> geth.is_mining
True
>>> geth.wait_for_dag(timeout=600)  # 等待最多10分钟,以便生成DAG。复制代码

DAG 功能目前仅适用于 epoch 0。spa

安装特定版本的 geth

此功能是实验性的,可能会发生重大变化。

可使用 py-geth 在列出的平台上安装如下任何版本的 geth 。

  • v1.5.6 (linux/osx)
  • v1.5.7 (linux/osx)
  • v1.5.8 (linux/osx)
  • v1.5.9 (linux/osx)
  • v1.6.0 (linux/osx)
  • v1.6.1 (linux/osx)
  • v1.6.2 (linux/osx)
  • v1.6.3 (linux/osx)
  • v1.6.4 (linux/osx)
  • v1.6.5 (linux/osx)
  • v1.6.6 (linux/osx)
  • v1.6.7 (linux/osx)
  • v1.7.0 (linux/osx)
  • v1.7.2 (linux/osx)
  • v1.8.1 (linux/osx)

能够经过命令行完成安装:

$ python -m geth.install v0.4.12复制代码

或者使用 install_geth 函数从 python 安装。

>>> from geth import install_geth
>>> install_geth('v1.7.0')复制代码

已安装的二进制文件能够在 $HOME/.py-geth 目录下找到。v1.7.0 二进制文件位于 $HOME/.py-geth/geth-v1.7.0/bin/geth

python开发相关IT技术群:887934385 复制代码

关于 DevGethProcess

DevGethProcess 旨在促进测试。在这方面,它预先配置以下。

  • 建立一个账户并分配 10 亿以太。
  • rpcipc 接口上都启用了全部 API。
  • 账户 0 已解锁。
  • 网络配置为不查找或链接到任何对等方。
  • 使用 1234networkid
  • 测试程度设为 5(DEBUG)
  • 使用单个线程启用挖掘。
  • RPC 接口尝试绑定到 8545,但若是此端口不可用,则会找到一个开放端口。
  • DevP2P 接口尝试绑定到 30303,但若是此端口不可用,将找到一个开放端口。

Gotchas

若是你在启用 mining 状况下运行(这是 DevGethProcess 默认设置,那么你可能须要手动生成 DAG。若是不这样作,那么它将在你第一次运行该过程时自动生成,这须要一段时间。

要手动生成它:

$ geth makedag 0 ~/.ethash复制代码

这在像 Travis-CI 这样的 CI 环境中尤为重要,在这种状况下,你的流程可能会在生成期间超时。

开发

克隆存储库而后运行:

pip install -e . -r requirements-dev.txt复制代码

运行测试

可使用如下命令运行测试:

py.test tests复制代码

或者你能够安装 tox 来运行完整的测试套件。

发布

须要 Pandoc 才能将 markdown README 转换为正确的格式,以便在 pypi 上正确呈现。

对于相似 Debian 的系统:

apt install pandoc复制代码

或者在 OSX 上:

brew install pandoc复制代码

要发布新版本:

make release bump=$$VERSION_PART_TO_BUMP$$复制代码

如何 bump 版本

此 repo 的版本格式为 {major}.{minor}.{patch} 表示 stable,{major}.{minor}.{patch} {major}.{minor}.{patch}-{stage}.{devnum} 表示 unstable(stage 能够是 alpha 或 beta)。

要在行中发布下一个版本,请指定要 bump 的部分,例如 make release bump=minormake release bump=devnum

若是你处于测试版,则 make release bump=stage 将切换为稳定版。

要在当前版本稳定时发出不稳定版本,请明确指定新版本,例如 make release bump="--new-version 4.0.0-alpha.1 devnum"

python开发相关IT技术群: 887934385 
相关文章
相关标签/搜索