pulkin / pyteleport

Snapshot, transmit, and resume python states

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

build pypi

icon

A proof-of-concept serialization, transmission and restoring python runtime.

About

pyteleport is capable of making snapshots of python runtime from (almost) aribtrary state, including locals, globals and stack. It then transforms snapshots into specially designed bytecode that resumes execution from the snapshot state. The bytecode can be run remotely: this way pyteleport teleports python runtime.

Install

pip install pyteleport

Example

term cast 0

Note that the two outputs were produced by different processes on different machines! This is what tp_bash does: it transmits the runtime from one python process to another (remotely).

Also works from within a stack:

def a():
    def b():
        def c():
            result = "hello"
            tp_bash(...)
            return result + " world"
        return len(c()) + float("3.5")
    return 5 * (3 + b())
assert a() == 87.5

API

TBD, see docstrings for the moment

How it works

  • You invoke teleport in your python script.
  • pyteleport collects the runtime state: globals, locals, stack.
  • pyteleport dumps the runtime into a specially designed "morph" bytecode which resumes from where teleport was invoked.
  • The bytecode is transmitted to the target environment and passed to a python interpreter there.
  • The remote python runs the bytecode which restores the runtime state. The python program casually resumes from where it was interrupted.
  • The local python runtime is terminated and simply pipes stdio from the target environment.

Known limitations

This is a proof of concept. The package works with cPython v3.8, 3.9, or 3.10.

What is implemented:

  • MWE: snapshot, serialize, transmit, restore
  • serialize generators
  • yield from
  • threads (currently ignored)
  • block stack: for,try, with
  • async (non-python stack; needs further investigation)
  • forking to remote (possible with bytecode sstack prediction)
  • back-teleport (needs API development)
  • nested teleport (needs minimal changes)
  • cross-fork communications (need API development)
  • REPL integration
  • detecting non-python stack (peek into past value stack?)

Won't fix:

  • non-python stack (not possible)
  • cross-version (too fragile)

License

LICENSE.md

About

Snapshot, transmit, and resume python states

License:BSD 2-Clause "Simplified" License


Languages

Language:Python 94.6%Language:Cython 5.4%