Skip to main content

Framework for writing distributed, fault tolerant and scalable applications

Project description


Spinoff is a framework for writing distributed, fault tolerant and scalable applications in Python. Spinoff is based on the Actor Model and borrows from Akka (location transparency, actor references, etc) and Erlang (processes, nodename@hosthost style node references (not implemented yet)).

Spinoff has been built using Twisted as the underlying framework and ZeroMQ (via pyzmq and a fork of txzmq) for remoting.

Spinoff is currently under continuous development but is nevertheless usable for writing real applications—its fault tolerance features also protect it against bugs in its own code.


The following is only a very small “peek preview” style example of what the framework can do. More examples and full documentation will follow soon.

# spinoff/examples/

from import Actor
from import Process
from spinoff.util.logging import dbg
from spinoff.util.async import sleep, with_timeout

class ExampleProcess(Process):
    def run(self):
        child = self.spawn(ExampleActor)

        while True:
            dbg("sending greeting to %r" % (child,))
            child << ('hello!', self.ref)

            dbg("waiting for ack from %r" % (child,))
            yield with_timeout(5.0, self.get('ack'))

            dbg("got 'ack' from %r; now sleeping a bit..." % (child,))
            yield sleep(1.0)

class ExampleActor(Actor):
    def pre_start(self):

    def receive(self, msg):
        content, sender = msg
        dbg("%r from %r" % (content, sender))
        sender << 'ack'

    def post_stop(self):

The example can be run using the following command:

twistd --nodaemon startnode --actor spinoff.examples.example1.ExampleProcess

Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Filename, size & hash SHA256 hash help File type Python version Upload date
spinoff-0.5.tar.gz (75.0 kB) Copy SHA256 hash SHA256 Source None

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN SignalFx SignalFx Supporter DigiCert DigiCert EV certificate StatusPage StatusPage Status page