select — Esperando la finalización de E/S¶
Este módulo proporciona acceso a las funciones select() y poll() disponibles en la mayoría de los sistemas operativos, devpoll() disponible en Solaris y derivados, epoll() disponible en Linux 2.5+ y kqueue() disponible en la mayoría de BSD. Tenga en cuenta que en Windows, solo funciona para sockets; en otros sistemas operativos, también funciona para otros tipos de archivos (en particular, en Unix, funciona en tuberías). No se puede usar en archivos normales para determinar si un archivo ha crecido desde la última lectura.
Nota
El módulo selectors permite la multiplexación de E/S de alto nivel y eficiente, construida sobre las primitivas del módulo select. Se alienta a los usuarios a utilizar el módulo selectors en su lugar, a menos que quieran un control preciso sobre las primitivas utilizadas de nivel OS.
El módulo define lo siguiente:
-
select.devpoll()¶ (Solo se admite en Solaris y derivados). Retorna un objeto de sondeo
/dev/poll; vea la sección Objetos de sondeo /dev/poll a continuación para conocer los métodos admitidos por los objetos devpoll.Los objetos
devpoll()están vinculados a la cantidad de descriptores de archivo permitidos en el momento de la creación de instancias. Si su programa reduce este valor,devpoll()fallará. Si su programa aumenta este valor,devpoll()puede retornar una lista incompleta de descriptores de archivos activos.El nuevo descriptor del archivo es non-inheritable.
Nuevo en la versión 3.3.
Distinto en la versión 3.4: El nuevo descriptor de archivo ahora no es heredable.
-
select.epoll(sizehint=-1, flags=0)¶ (Solo se admite en Linux 2.5.44 y versiones posteriores). Retorna un objeto de sondeo de borde, que se puede usar como interfaz de disparo de nivel o de borde para eventos de E/S.
sizehint informa a epoll sobre el número esperado de eventos a ser registrados. Debe ser positivo o -1 para usar el valor predeterminado. Solo se usa en sistemas más antiguos donde
epoll_create1()no está disponible; de lo contrario no tiene ningún efecto (aunque su valor aún está marcado).flags está en desuso y se ignora por completo. Sin embargo, cuando se proporciona, su valor debe ser
0oselect.EPOLL_CLOEXEC, de lo contrario, se generaráOSError.Consulte la sección Objetos de sondeo de Edge y Level Trigger (epoll) a continuación para conocer los métodos admitidos por los objetos epolling.
Los objetos
epolladmiten el protocolo context management: cuando se usa en una declaraciónwith, el nuevo descriptor de archivo se cierra automáticamente al final del bloque.El nuevo descriptor del archivo es non-inheritable.
Distinto en la versión 3.3: Se agregó el parámetro flags.
Distinto en la versión 3.4: Se agregó soporte para la declaración
with. El nuevo descriptor de archivo ahora no es heredable.Obsoleto desde la versión 3.4: El parámetro flags.
select.EPOLL_CLOEXECse usa por defecto ahora. Useos.set_inheritable()para hacer que el descriptor de archivo sea heredable.
-
select.poll()¶ (No es compatible con todos los sistemas operativos). Retorna un objeto de sondeo, que admite registrar y anular el registro de descriptores de archivo, y luego sondearlos para eventos de I/O; vea la sección Sondeo de objetos a continuación para conocer los métodos admitidos por los objetos de sondeo.
-
select.kqueue()¶ (Solo se admite en BSD). Retorna un objeto de cola del kernel; vea la sección Objetos Kqueue a continuación para conocer los métodos admitidos por los objetos kqueue.
El nuevo descriptor del archivo es non-inheritable.
Distinto en la versión 3.4: El nuevo descriptor de archivo ahora no es heredable.
-
select.kevent(ident, filter=KQ_FILTER_READ, flags=KQ_EV_ADD, fflags=0, data=0, udata=0)¶ (Solo se admite en BSD). Retorna un objeto de evento del kernel; vea la sección Objetos Kevent a continuación para conocer los métodos admitidos por los objetos kevent.
-
select.select(rlist, wlist, xlist[, timeout])¶ This is a straightforward interface to the Unix
select()system call. The first three arguments are iterables of “waitable objects”: either integers representing file descriptors or objects with a parameterless method namedfileno()returning such an integer:rlist: espera hasta que esté listo para leer
wlist: espera hasta que esté listo para escribir
xlist: espera una «condición excepcional» (consulte la página del manual para ver lo que su sistema considera tal condición)
Empty iterables are allowed, but acceptance of three empty iterables is platform-dependent. (It is known to work on Unix but not on Windows.) The optional timeout argument specifies a time-out as a floating point number in seconds. When the timeout argument is omitted the function blocks until at least one file descriptor is ready. A time-out value of zero specifies a poll and never blocks.
El valor de retorno es un triple de listas de objetos que están listos: subconjuntos de los primeros tres argumentos. Cuando se alcanza el tiempo de espera sin que esté listo un descriptor de archivo, se retornan tres listas vacías.
Among the acceptable object types in the iterables are Python file objects (e.g.
sys.stdin, or objects returned byopen()oros.popen()), socket objects returned bysocket.socket(). You may also define a wrapper class yourself, as long as it has an appropriatefileno()method (that really returns a file descriptor, not just a random integer).Nota
Los objetos de archivo en Windows no son admisibles, pero los sockets sí. En Windows, la función subyacente
select()es proporcionada por la biblioteca WinSock, y no maneja los descriptores de archivo que no se originan en WinSock.Distinto en la versión 3.5: La función ahora se vuelve a intentar con un tiempo de espera (timeout) recalculado cuando se interrumpe por una señal, excepto si el controlador de señal genera una excepción (ver PEP 475 para la justificación), en lugar de generar
InterruptedError.
-
select.PIPE_BUF¶ El número mínimo de bytes que se pueden escribir sin bloquear en una tubería cuando la tubería ha sido reportada como lista para escribir por
select(),poll()u otra interfaz en este módulo. Esto no se aplica a otro tipo de objetos similares a archivos, como los sockets.Este valor es garantizado por POSIX para ser menor a 512.
Availability: Unix
Nuevo en la versión 3.2.
Objetos de sondeo /dev/poll¶
Solaris y derivados tienen /dev/poll. Mientras que select() es O(descriptor de archivo más alto) y poll() es O (número de descriptores de archivo), /dev/poll es O(descriptores de archivo activos).
El comportamiento /dev/poll está muy cerca del estándar objeto poll().
-
devpoll.close()¶ Cierra el descriptor de archivo del objeto de sondeo.
Nuevo en la versión 3.4.
-
devpoll.closed¶ Truesi el objeto de sondeo está cerrado.Nuevo en la versión 3.4.
-
devpoll.fileno()¶ Retorna el número de descriptor de archivo del objeto de sondeo.
Nuevo en la versión 3.4.
-
devpoll.register(fd[, eventmask])¶ Registra un descriptor de archivo con el objeto de sondeo. Las futuras llamadas al método
poll()comprobarán si el descriptor del archivo tiene algún evento I/O pendiente. fd puede ser un entero o un objeto con un métodofileno()que retorna un entero. Los objetos de archivo implementanFileno(), por lo que también pueden usarse como argumento.eventmask es una máscara de bits opcional que describe el tipo de eventos que desea verificar. Las constantes son las mismas que con el objeto
poll(). El valor predeterminado es una combinación de las constantesPOLLIN,POLLPRIyPOLLOUT.Advertencia
Registra un descriptor de archivo que ya está registrado no es un error, pero el resultado no está definido. La acción apropiada es anular el registro o modificarlo primero. Esta es una diferencia importante en comparación con
poll().
-
devpoll.modify(fd[, eventmask])¶ Este método hace un
unregister()seguido de aregister(). Es (un poco) más eficiente que hacer lo mismo explícitamente.
-
devpoll.unregister(fd)¶ Elimina un descriptor de archivo que está siendo rastreado por un objeto de sondeo. Al igual que el método
register(), fd puede ser un entero o un objeto con un métodofileno()que retorna un entero.Al intentar eliminar un descriptor de archivo que nunca se registró se ignora de forma segura.
-
devpoll.poll([timeout])¶ Sondea el conjunto de descriptores de archivos registrados y retorna una lista posiblemente vacía que contiene
(fd, event)2 tuplas para los descriptores que tienen eventos o errores que informar. fd es el descriptor de archivo, y event es una máscara de bits con bits establecidos para los eventos informados para ese descriptor —POLLINpara la entrada en espera,POLLOUTpara indicar que el descriptor puede ser escrito, y así sucesivamente. Una lista vacía indica que se agotó el tiempo de espera de la llamada y que ningún descriptor de archivos tuvo ningún evento que informar. Si se da timeout, especifica el período de tiempo en milisegundos que el sistema esperará por los eventos antes de regresar. Si se omite timeout, es -1 o esNone, la llamada se bloqueará hasta que haya un evento para este objeto de encuesta.Distinto en la versión 3.5: La función ahora se vuelve a intentar con un tiempo de espera (timeout) recalculado cuando se interrumpe por una señal, excepto si el controlador de señal genera una excepción (ver PEP 475 para la justificación), en lugar de generar
InterruptedError.
Objetos de sondeo de Edge y Level Trigger (epoll)¶
https://linux.die.net/man/4/epoll
eventmask
Constante
Significado
EPOLLINDisponible para lectura
EPOLLOUTDisponible para escritura
EPOLLPRIUrgente para lectura
EPOLLERRLa condición de error ocurrió en la asociación. fd
EPOLLHUPSe colgó en la asociación. fd
EPOLLETEstablece el comportamiento en Edge Trigger, el valor predeterminado es Level Trigger
EPOLLONESHOTEstablece el comportamiento en one-shot. Después de que se retira un evento, el fd se deshabilita internamente
EPOLLEXCLUSIVEDespierta solo un objeto epoll cuando el fd asociado tiene un evento. El valor predeterminado (si este flag no está configurado) es activar todos los objetos epoll que sondean en un fd.
EPOLLRDHUPSocket de flujo de conexión cerrada por pares o apagado escribiendo la mitad de la conexión.
EPOLLRDNORMEquivalente a
EPOLLIN
EPOLLRDBANDLa banda de datos de prioridad se puede leer.
EPOLLWRNORMEquivalente a
EPOLLOUT
EPOLLWRBANDSe pueden escribir datos de prioridad.
EPOLLMSGIgnorado.
Nuevo en la versión 3.6:
EPOLLEXCLUSIVEfue agregado. Solo es compatible con Linux Kernel 4.5 o posterior.
-
epoll.close()¶ Cierra el descriptor del archivo de control del objeto epoll.
-
epoll.closed¶ Truesi el objeto epoll está cerrado.
-
epoll.fileno()¶ Retorna el número de descriptor de archivo del control fd.
-
epoll.fromfd(fd)¶ Crea un objeto epoll a partir de un descriptor de archivo dado.
-
epoll.register(fd[, eventmask])¶ Registra un descriptor fd con el objeto epoll.
-
epoll.modify(fd, eventmask)¶ Modifica un descriptor de archivo registrado.
-
epoll.unregister(fd)¶ Elimina un descriptor de archivo registrado del objeto epoll.
-
epoll.poll(timeout=None, maxevents=-1)¶ Espera los eventos. tiempo de espera (timeout) en segundos (float)
Distinto en la versión 3.5: La función ahora se vuelve a intentar con un tiempo de espera (timeout) recalculado cuando se interrumpe por una señal, excepto si el controlador de señal genera una excepción (ver PEP 475 para la justificación), en lugar de generar
InterruptedError.
Sondeo de objetos¶
La llamada al sistema: poll(), compatible con la mayoría de los sistemas Unix, proporciona una mejor escalabilidad para los servidores de red que dan servicio a muchos, muchos clientes al mismo tiempo. poll() escala mejor porque la llamada al sistema solo requiere enumerar los descriptores de archivo de interés, mientras que select() construye un mapa de bits, activa bits para los fds de interés, y luego todo el mapa de bits debe escanearse linealmente nuevamente. select() es O (descriptor de archivo más alto), mientras que poll() es O(número de descriptores de archivo).
-
poll.register(fd[, eventmask])¶ Registra un descriptor de archivo con el objeto de sondeo. Las futuras llamadas al método
poll()comprobarán si el descriptor del archivo tiene algún evento I/O pendiente. fd puede ser un entero o un objeto con un métodofileno()que retorna un entero. Los objetos de archivo implementanFileno(), por lo que también pueden usarse como argumento.eventmask es una máscara de bits opcional que describe el tipo de eventos que se desea verificar y puede ser una combinación de las constantes
POLLIN,POLLPRI, yPOLLOUT, descrito en la mesa de abajo. Si no se especifica, el valor predeterminado utilizado verificará los 3 tipos de eventos.Constante
Significado
POLLINHay datos para leer
POLLPRIHay datos urgentes para leer
POLLOUTLista para la salida: la escritura no bloqueará
POLLERRCondición de error de algún tipo
POLLHUPColgado
POLLRDHUPSocket de flujo de conexión cerrada por pares, o apagado escribiendo la mitad de la conexión
POLLNVALSolicitud no válida: descriptor no abierto
Al registrar un descriptor de archivo que ya está registrado no es un error y tiene el mismo efecto que registrar el descriptor exactamente una vez.
-
poll.modify(fd, eventmask)¶ Modifica un fd ya registrado. Esto tiene el mismo efecto que
register(fd, eventmask). Si se intenta modificar un descriptor de archivo que nunca se registró, se genera una excepciónOSErrorcon errnoENOENT.
-
poll.unregister(fd)¶ Elimina un descriptor de archivo que está siendo rastreado por un objeto de sondeo. Al igual que el método
register(), fd puede ser un entero o un objeto con un métodofileno()que retorna un entero.Intenta eliminar un descriptor de archivo que nunca se registró provoca una excepción
KeyError.
-
poll.poll([timeout])¶ Sondea el conjunto de descriptores de archivos registrados y retorna una lista posiblemente vacía que contiene
(fd, event)y 2 tuplas para los descriptores que tienen eventos o errores que informar. fd es el descriptor de archivo, y event es una máscara de bits con bits establecidos para los eventos informados para ese descriptor —POLLINpara la entrada en espera,POLLOUTpara indicar que el descriptor puede ser escrito, y así sucesivamente. Una lista vacía indica que se agotó el tiempo de espera de la llamada y que ningún descriptor de archivos tuvo ningún evento que informar. Si se da timeout , especifica el período de tiempo en milisegundos que el sistema esperará por los eventos antes de regresar. Si se omite timeout, es negativo, oNone, la llamada se bloqueará hasta que haya un evento para este objeto de encuesta.Distinto en la versión 3.5: La función ahora se vuelve a intentar con un tiempo de espera (timeout) recalculado cuando se interrumpe por una señal, excepto si el controlador de señal genera una excepción (ver PEP 475 para la justificación), en lugar de generar
InterruptedError.
Objetos Kqueue¶
-
kqueue.close()¶ Cierra el descriptor del archivo de control del objeto kqueue.
-
kqueue.closed¶ Truesi el objeto kqueue está cerrado.
-
kqueue.fileno()¶ Retorna el número de descriptor de archivo del control fd.
-
kqueue.fromfd(fd)¶ Crea un objeto kqueue a partir de un descriptor de archivo dado.
-
kqueue.control(changelist, max_events[, timeout]) → eventlist¶ Interfaz de bajo nivel para kevent
la lista de cambios (changelist) debe ser iterable de objetos kevent o
Nonemax_events debe ser 0 o un entero positivo
tiempo de espera (timeout) en segundos (posible con floats); el valor predeterminado es
None, para esperar para siempre
Distinto en la versión 3.5: La función ahora se vuelve a intentar con un tiempo de espera (timeout) recalculado cuando se interrumpe por una señal, excepto si el controlador de señal genera una excepción (ver PEP 475 para la justificación), en lugar de generar
InterruptedError.
Objetos Kevent¶
https://www.freebsd.org/cgi/man.cgi?query=kqueue&sektion=2
-
kevent.ident¶ Valor utilizado para identificar el evento. La interpretación depende del filtro, pero generalmente es el descriptor de archivo. En el constructor, ident puede ser un int o un objeto con un método
fileno(). kevent almacena el entero internamente.
-
kevent.filter¶ Nombre del filtro del kernel.
Constante
Significado
KQ_FILTER_READToma un descriptor y retorna cada vez que hay datos disponibles para leer
KQ_FILTER_WRITEToma un descriptor y retorna cada vez que hay datos disponibles para escribir
KQ_FILTER_AIOSolicitudes de AIO
KQ_FILTER_VNODERetorna cuando ocurre uno o más de los eventos solicitados observados en fflag
KQ_FILTER_PROCVigila los eventos en un id de proceso
KQ_FILTER_NETDEVVigila los eventos en un dispositivo de red [no disponible en Mac OS X]
KQ_FILTER_SIGNALRetorna cada vez que la señal observada se entrega al proceso
KQ_FILTER_TIMEREstablece un temporizador arbitrario
-
kevent.flags¶ Acción de filtro.
Constante
Significado
KQ_EV_ADDAgrega o modifica un evento
KQ_EV_DELETEElimina un evento de la cola
KQ_EV_ENABLEPermitscontrol() para retornar el evento
KQ_EV_DISABLEDisablesevent
KQ_EV_ONESHOTElimina evento después de la primera aparición
KQ_EV_CLEARRestablece el estado después de recuperar un evento
KQ_EV_SYSFLAGSevento interno
KQ_EV_FLAG1evento interno
KQ_EV_EOFFiltrar la condición específica de EOF
KQ_EV_ERRORVer valores de retorno
-
kevent.fflags¶ Filtrar flags específicas.
KQ_FILTER_READyKQ_FILTER_WRITEbandera de filtro:Constante
Significado
KQ_NOTE_LOWATmarca de agua baja de un socket buffer
KQ_FILTER_VNODEbandera de filtro:Constante
Significado
KQ_NOTE_DELETEunlink() fue llamado
KQ_NOTE_WRITEuna escritura ha ocurrido
KQ_NOTE_EXTENDel archivo fue extendido
KQ_NOTE_ATTRIBun atributo fue cambiado
KQ_NOTE_LINKel recuento de enlaces ha cambiado
KQ_NOTE_RENAMEel archivo fue renombrado
KQ_NOTE_REVOKEse revocó el acceso al archivo
KQ_FILTER_PROCbandera de filtro:Constante
Significado
KQ_NOTE_EXITel proceso ha terminado (exited)
KQ_NOTE_FORKel proceso ha llamado a fork()
KQ_NOTE_EXECel proceso ha ejecutado un nuevo proceso
KQ_NOTE_PCTRLMASKflag de filtro interno
KQ_NOTE_PDATAMASKflag de filtro interno
KQ_NOTE_TRACKsigue un proceso a través de fork()
KQ_NOTE_CHILDretornado en el proceso hijo para NOTE_TRACK
KQ_NOTE_TRACKERRincapaz de adjuntar a un proceso hijo
KQ_FILTER_NETDEVbanderas de filtro (no disponible en Mac OS X):Constante
Significado
KQ_NOTE_LINKUPel enlace está funcionando
KQ_NOTE_LINKDOWNel enlace está caído
KQ_NOTE_LINKINVel estado del enlace es invalido
-
kevent.data¶ Filtrar datos específicos.
-
kevent.udata¶ Valor definido por el usuario.