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:
- 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 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 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.
- 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)