This HOWTO introduces the Twisted reactor, describes the basics of the reactor and links to the various reactor interfaces.
Reactor Basics
The reactor is the core of the event loop within Twisted -- the loop which drives applications using Twisted. The event loop is a programming construct that waits for and dispatches events or messages in a program. It works by calling some internal or external "event provider", which generally blocks until an event has arrived, and then calls the relevant event handler ("dispatches the event"). The reactor provides basic interfaces to a number of services, including network communications, threading, and event dispatching.
For information about using the reactor and the Twisted event loop, see:
- the event dispatching howtos: Scheduling and Using Deferreds <defer> ;
- the communication howtos: TCP servers , TCP clients <clients> , UDP networking <udp> and Using processes <process> ; and
- Using threads .
There are multiple implementations of the reactor, each modified to provide better support for specialized features over the default implementation. More information about these and how to use a particular implementation is available via Choosing a Reactor .
Twisted applications can use the interfaces in twisted.application.service to configure and run the application instead of using boilerplate reactor code. See Using Application for an introduction to Application.
Using the reactor object
You can get to the reactor <twisted.internet.reactor> object using the following code:
from twisted.internet import reactor
The reactor usually implements a set of interfaces, but depending on the chosen reactor and the platform, some of the interfaces may not be implemented:
- IReactorCore <twisted.internet.interfaces.IReactorCore> : Core (required) functionality.
- IReactorFDSet <twisted.internet.interfaces.IReactorFDSet> : Use FileDescriptor objects.
- IReactorProcess <twisted.internet.interfaces.IReactorProcess> : Process management. Read the Using Processes document for more information.
- IReactorSSL <twisted.internet.interfaces.IReactorSSL> : SSL networking support.
- IReactorTCP <twisted.internet.interfaces.IReactorTCP> : TCP networking support. More information can be found in the Writing Servers and Writing Clients documents.
- IReactorThreads <twisted.internet.interfaces.IReactorThreads> : Threading use and management. More information can be found within Threading In Twisted .
- IReactorTime <twisted.internet.interfaces.IReactorTime> : Scheduling interface. More information can be found within Scheduling Tasks .
- IReactorUDP <twisted.internet.interfaces.IReactorUDP> : UDP networking support. More information can be found within UDP Networking .
- IReactorUNIX <twisted.internet.interfaces.IReactorUNIX> : UNIX socket support.
- IReactorSocket <twisted.internet.interfaces.IReactorSocket> : Third-party socket support.