selectors
— Multiplexación de E/S de alto nivel¶
Nuevo en la versión 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.
Define una clase base abstracta BaseSelector
, junto con varias implementaciones concretas (KqueueSelector
, EpollSelector
…), que se pueden utilizar para esperar la notificación de disponibilidad para E/S en varios objetos de archivo. De aquí en adelante, «objeto de archivo» hace referencia a cualquier objeto con un método fileno()
o un descriptor de archivo sin procesar. Véase 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.
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
EVENT_READ
Disponible para lectura
EVENT_WRITE
Disponible para escritura
-
class
selectors.
SelectorKey
¶ La clase
SelectorKey
es unanamedtuple
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étodosBaseSelector
.-
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. UseDefaultSelector
en su lugar, o unSelectSelector
,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 unValueError
en caso de una máscara de evento o un descriptor de archivo no válidos, oKeyError
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 unKeyError
si fileobj no está registrado. Se lanzará unValueError
si fileobj no es válido (por ejemplo, no tiene el métodofileno ()
o su métodofileno ()
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 deBaseSelector.register(fileobj, events, data)()
, excepto que se puede implementar de manera más eficiente.Esto retorna una nueva instancia de
SelectorKey
, o lanza unValueError
en caso de una máscara de evento o un descriptor de archivo no válidos, oKeyError
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. Sitimeout <= 0
, la llamada no se bloqueará y reportará los objetos de archivo actualmente listos. Si timeout esNone
, 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 unKeyError
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 instanciaSelectorKey
asociada
-
abstractmethod
-
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.
Nuevo en la versión 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)