selectors — High-level I/O multiplexing

Added in version 3.4.

Código fuente: Lib/selectors.py


Introducción

Este módulo permite multiplexación de E/S eficiente y de alto nivel, basada en los primitivos del módulo select. Se recomienda a los usuarios utilizar este módulo en su lugar, a menos que deseen un control preciso sobre los primitivos a nivel de sistema operativo utilizados.

It defines a BaseSelector abstract base class, along with several concrete implementations (KqueueSelector, EpollSelector…), that can be used to wait for I/O readiness notification on multiple file objects. In the following, «file object» refers to any object with a fileno() method, or a raw file descriptor. See file object.

DefaultSelector es un alias de la implementación más eficiente disponible en la plataforma actual: esta debería ser la opción predeterminada para la mayoría de los usuarios.

Nota

El tipo de objetos de archivo admitidos depende de la plataforma: en Windows, se admiten sockets, pero no pipes, mientras que en Unix, ambos son compatibles (también se pueden admitir algunos otros tipos, como FIFOs o dispositivos de archivo especiales).

Ver también

select

Módulo de multiplexación de E/S de bajo nivel.

Availability: not WASI.

This module does not work or is not available on WebAssembly. See Plataformas WebAssembly for more information.

Clases

Jerarquía de clases:

BaseSelector
+-- SelectSelector
+-- PollSelector
+-- EpollSelector
+-- DevpollSelector
+-- KqueueSelector

De aquí en adelante, events es una máscara bit a bit que indica qué eventos de E/S se deben esperar en un objeto de archivo determinado. Puede ser cualquier combinación de las siguientes constantes de módulo:

Constante

Significado

selectors.EVENT_READ

Disponible para lectura

selectors.EVENT_WRITE

Disponible para escritura

class selectors.SelectorKey

La clase SelectorKey es una namedtuple que se utiliza para asociar un objeto de archivo a su descriptor de archivo subyacente, máscara de evento seleccionada y datos adjuntos. Es retornada por varios métodos BaseSelector.

fileobj

Objeto de archivo registrado.

fd

Descriptor de archivo subyacente.

events

Eventos que se deben esperar en este objeto de archivo.

data

Datos opacos opcionales asociados a este objeto de archivo: por ejemplo, podría usarse para almacenar un ID de sesión por cliente.

class selectors.BaseSelector

Un BaseSelector se usa para esperar a que el evento de E/S esté listo en varios objetos de archivo. Admite el registro y la cancelación del registro de secuencias de archivos y un método para esperar eventos de E/S en esas secuencias, con un tiempo de espera opcional. Es una clase base abstracta, por lo que no se puede crear una instancia. Use DefaultSelector en su lugar, o un SelectSelector, KqueueSelector, etc. si deseas usar específicamente una implementación y su plataforma la admite. BaseSelector y sus implementaciones concretas soportan el protocolo context manager.

abstractmethod register(fileobj, events, data=None)

Registra un objeto de archivo para su selección y lo monitoriza en busca de eventos de E/S.

fileobj es el objeto de archivo a monitorear. Puede ser un descriptor de archivo de tipo entero o un objeto con un método fileno(). events es una máscara bit a bit de eventos para monitorear. data es un objeto opaco.

Esto retorna una nueva instancia SelectorKey, o lanza un ValueError en caso de una máscara de evento o un descriptor de archivo no válidos, o KeyError si el objeto de archivo ya está registrado.

abstractmethod unregister(fileobj)

Anula el registro de un objeto de archivo de la selección y lo elimina del monitoreo. Se anulará el registro de un objeto de archivo antes de cerrarlo.

fileobj debe ser un objeto de archivo previamente registrado.

Esto retorna la instancia SelectorKey asociada, o lanza un KeyError si fileobj no está registrado. Se lanzará un ValueError si fileobj no es válido (por ejemplo, no tiene el método fileno () o su método fileno () tiene un valor de retorno no válido).

modify(fileobj, events, data=None)

Cambia los eventos monitorizados de un objeto de archivo registrado o los datos adjuntos.

Esto es equivalente a BaseSelector.unregister(fileobj) seguido de BaseSelector.register(fileobj, events, data), excepto que se puede implementar de manera más eficiente.

Esto retorna una nueva instancia de SelectorKey, o lanza un ValueError en caso de una máscara de evento o un descriptor de archivo no válidos, o KeyError si el objeto de archivo no está registrado.

abstractmethod select(timeout=None)

Espera hasta que algunos objetos de archivo registrados estén listos o el tiempo de espera expire.

Si timeout > 0, esto especifica el tiempo máximo de espera, en segundos. Si timeout <= 0, la llamada no se bloqueará y reportará los objetos de archivo actualmente listos. Si timeout es None, la llamada se bloqueará hasta que un objeto de archivo monitorizado esté listo.

Retorna una lista de tuplas (key, events), una por cada objeto de archivo listo.

key es la instancia SelectorKey correspondiente a un objeto de archivo listo. events es una máscara de bits de eventos listos en este objeto de archivo.

Nota

Este método puede regresar antes de que cualquier objeto de archivo esté listo o haya transcurrido el tiempo de espera si el proceso actual recibe una señal: en este caso, se retornará una lista vacía.

Distinto en la versión 3.5: El selector ahora se reintenta con un tiempo de espera recalculado cuando es interrumpido por una señal si el gestor de señales no lanzó una excepción (ver PEP 475 para la justificación), en lugar de retornar una lista vacía de eventos antes del tiempo de espera.

close()

Cierra el selector.

Se debe llamar para asegurarse de que se libera cualquier recurso subyacente. El selector no se utilizará una vez cerrado.

get_key(fileobj)

Retorna la clave asociada con un objeto de archivo registrado.

Esto retorna la instancia SelectorKey asociada a este objeto de archivo, o lanza un KeyError si el objeto de archivo no está registrado.

abstractmethod get_map()

Retorna un mapeo asociando objetos de archivo a las llaves del selector.

Retorna una instancia de Mapping mapeando objetos de archivo registrados a su instancia SelectorKey asociada.

class selectors.DefaultSelector

La clase de selector predeterminada, utiliza la implementación más eficiente disponible en la plataforma actual. Esta debería ser la opción predeterminada para la mayoría de los usuarios.

class selectors.SelectSelector

Selector basado en select.select().

class selectors.PollSelector

Selector basado en select.poll().

class selectors.EpollSelector

Selector basado en select.epoll().

fileno()

Esto retorna el descriptor de archivo utilizado por el objeto select.epoll() subyacente.

class selectors.DevpollSelector

Selector basado en select.devpoll().

fileno()

Esto retorna el descriptor de archivo utilizado por el objeto select.devpoll() subyacente.

Added in version 3.5.

class selectors.KqueueSelector

Selector basado en select.kqueue().

fileno()

Esto retorna el descriptor de archivo utilizado por el objeto select.kqueue() subyacente.

Ejemplos

Aquí hay una implementación simple de un servidor de eco:

import selectors
import socket

sel = selectors.DefaultSelector()

def accept(sock, mask):
    conn, addr = sock.accept()  # Should be ready
    print('accepted', conn, 'from', addr)
    conn.setblocking(False)
    sel.register(conn, selectors.EVENT_READ, read)

def read(conn, mask):
    data = conn.recv(1000)  # Should be ready
    if data:
        print('echoing', repr(data), 'to', conn)
        conn.send(data)  # Hope it won't block
    else:
        print('closing', conn)
        sel.unregister(conn)
        conn.close()

sock = socket.socket()
sock.bind(('localhost', 1234))
sock.listen(100)
sock.setblocking(False)
sel.register(sock, selectors.EVENT_READ, accept)

while True:
    events = sel.select()
    for key, mask in events:
        callback = key.data
        callback(key.fileobj, mask)