A proof-of-concept snapshot, transmission and restoring python runtime
Project description
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
hello
implementation:
from socket import gethostname
from os import getpid
def hello():
print(f"hello from {gethostname()} / pid {getpid()}")
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
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 whereteleport
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
- threads (currently ignored)
- block stack:
for
,try
,with
-
async
(never tested but likely needs minimal changes) -
yield from
(never tested) - forking to remote (non-destructive teleport, needs investigating)
- back-teleport (needs API development)
- nested teleport (needs minimal changes)
- cross-fork communications (need API development)
- REPL integration
- cross-version (needs investigating)
Won't fix:
- non-python stack (not possible)
License
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.