logging.handlers
— Gestores de logging¶
Código fuente Lib/logging/handlers.py
Estos gestores son muy útiles y están provistos en este paquete. Nota que tres de los gestores de las clases (StreamHandler
, FileHandler
and NullHandler
) están definidos en propio módulo logging
pero fueron documentados aquí junto con los otros gestores.
StreamHandler¶
La clase StreamHandler
ubicada en el paquete núcleo logging
envía la salida del logging a un stream como sys.stdout, sys.stderr o cualquier objeto tipo archivo (o mas precisamente cualquier objeto que soporte los métodos write()
y flush()
).
-
class
logging.
StreamHandler
(stream=None)¶ Retorna una nueva instancia de la clase
StreamHandler
. Si stream esta especificado, la instancia lo usará para la salida del registro, sino se usará sys.stderr.-
emit
(record)¶ Si esta especificado un formateador se usará para formatear el registro. Luego se escribe el registro al stream con un terminador. Si hay información de excepción presente, se formateará usando
traceback.print_exception()
y se añadirá al stream.
-
flush
()¶ Descarga el stream llamando a su método
flush()
. Nota que el métodoclose()
es heredado de la claseHandler
y por lo tanto no produce ninguna salida. Por eso muchas veces será necesario invocar al método explícitoflush()
.
-
setStream
(stream)¶ Establece el stream de la instancia a un valor especifico, si este es diferente. El anterior stream es vaciado antes de que el nuevo stream sea establecido.
- Parámetros
stream – El stream que el gestor debe usar.
- Devuelve
el anterior stream. si el stream cambió o None si no cambió.
Nuevo en la versión 3.7.
-
Distinto en la versión 3.2: La clase StreamHandler
ahora tiene un atributo terminador` con valor por defecto ``'\n'
, que se usa como terminador cuando se escribe un registro formateado a un stream. Si no se quiere esta terminación de nueva línea, se puede establecer el atributo de la instancia del gestor``terminator`` para vaciar la cadena de caracteres. En versiones anteriores el terminador era codificado como '\n'
.
FileHandler¶
La clase FileHandler
está localizada en el paquete núcleo logging
, envía la salida del logging a un archivo de disco. Hereda la funcionalidad de salida de la clase StreamHandler
.
-
class
logging.
FileHandler
(filename, mode='a', encoding=None, delay=False)¶ Retorna una nueva instancia de la clase
FileHandler
. Abre el archivo especificado y se usa como un stream para logging. si mode no se especifica se usa'a'
. Si encoding no esNone
, se usará para abrir el archivo con esa codificación. Si delay es true entonces se difiere la apertura del archivo hasta la primer llamada al métodoemit()
. Por defecto el archivo crece indefinidamente.Distinto en la versión 3.6: Así como valores de cadena de caracteres, también se aceptan objetos de la clase
Path
para el argumento «filename».-
close
()¶ Cierra el archivo.
-
emit
(record)¶ Da la salida del registro al archivo.
-
NullHandler¶
Nuevo en la versión 3.1.
La clase NullHandler
está ubicada en el núcleo biblioteca logging
. No realiza ningún formateo o salida. Es en esencia un gestor “no-op” para uso de desarrolladores de bibliotecas.
-
class
logging.
NullHandler
¶ Retorna una nueva instancia de la clase
NullHandler
.-
emit
(record)¶ Este método no realiza ninguna acción.
-
handle
(record)¶ Este método no realiza ninguna acción.
-
createLock
()¶ Este método retorna
None
para el bloqueo , dado que no hay una E/S subyacente cuyo acceso se necesite serializar.
-
Véase Configurando Logging para una biblioteca para mas información en como usar la clase NullHandler
.
WatchedFileHandler¶
La clase WatchedFileHandler
está ubicada en el módulo logging.handlers
, es una clase FileHandler
que vigila a que archivo se está enviando el logging. Si el archivo cambia , este se cerrará y se volverá a abrir usando el nombre de archivo.
Puede suceder que haya un cambio de archivo por uso de programas como newsyslog y logrotate que realizan una rotación del archivo log. Este gestor destinado para uso bajo Unix/Linux controla el archivo para ver si hubo cambios desde la última emisión. (Un archivo se considera que cambió si su dispositivo o nodo índice cambió). Si el archivo cambió entonces el anterior stream de archivo se cerrará, y se abrirá el nuevo para obtener un nuevo stream.
Este gestor no es apropiado para uso bajo Windows porque bajo Windows los archivos log abiertos no se pueden mover o renombrar. Logging abre los archivos con bloqueos exclusivos y entonces no hay necesidad de usar el gestor. Por otra parte ST_INO no es soportado bajo Windows. La función stat()
siempre retorna cero para este valor.
-
class
logging.handlers.
WatchedFileHandler
(filename, mode='a', encoding=None, delay=False)¶ Retorna una nueva instancia de la clase
WatchedFileHandler
. El archivo especificado se abre y usa como el stream para logging. Si mode no se especifica se usará'a'
. Si encoding no esNone
, se usa para abrir el archivo con esa codificación. Si delay es true se diferirá la apertura del archivo hasta tanto se llame al métodoemit()
. Por defecto el archivo crecerá indefinidamente.Distinto en la versión 3.6: Así como valores de cadena de caracteres, también se aceptan objetos de la clase
Path
para el argumento «filename».-
reopenIfNeeded
()¶ Revisa si el archivo cambió. Si hubo cambio, el stream existente se vacía y cierra y el archivo se abre nuevamente. Típicamente es un precursor para dar salida del registro a un archivo.
Nuevo en la versión 3.6.
-
emit
(record)¶ Da salida al registro a un archivo, pero primero invoca al método
reopenIfNeeded()
para reabrir el archivo si es que cambió.
-
BaseRotatingHandler¶
La clase BaseRotatingHandler
ubicada en el módulo logging.handlers
es la clase base para rotar los gestores de archivos de clases RotatingFileHandler
y TimedRotatingFileHandler
. No debería ser necesario instanciar esta clase, pero tiene métodos y atributos que quizá se necesiten sobrescribir (override).
-
class
logging.handlers.
BaseRotatingHandler
(filename, mode, encoding=None, delay=False)¶ Los parámetros son como los de la clase
FileHandler
. Los atributos son:-
namer
¶ Si este atributo se establece como invocable, el método
rotation_filename()
delega a este invocable. Los parámetros pasados al invocable son aquellos pasados al métodorotation_filename()
.Nota
La función de nombrado es invocada unas cuantas veces durante el volcado (rollover) , entonces debe ser tan simple y rápida como sea posible. Debe también retornar siempre la misma salida para una misma entrada, de otra manera el volcado puede no funcionar como se espera.
Nuevo en la versión 3.3.
-
rotator
¶ Si este atributo se estableció como invocable, el método
rotate()
delega a este invocable. Los parámetros pasados al invocable son aquellos pasados al métodorotate()
.Nuevo en la versión 3.3.
-
rotation_filename
(default_name)¶ Modifica el nombre de un archivo log cuando esta rotando.
Esto esta previsto para que pueda usarse un nombre de archivo personalizado.
La implementación por defecto llama al atributo “namer” del gestor, si este es invocable, pasando el nombre por defecto a él. Si el atributo no es invocable (por defecto es
None
) el nombre se retorna sin cambios.- Parámetros
default_name – El nombre por defecto para el archivo de log.
Nuevo en la versión 3.3.
-
rotate
(source, dest)¶ Cuando está rotando, rotar el actual log.
La implementación por defecto llama al atributo “rotator” del gestor, si es invocable, pasando los argumentos de origen y destino a él. Si no se puede invocar (porque el atributo por defecto es “None”) el origen es simplemente renombrado al destino.
- Parámetros
source – El nombre de archivo origen . Normalmente el nombre de archivo base, por ejemplo “test.log”.
dest – El nombre de archivo de destino. Normalmente es el nombre al que se rota el archivo origen por ejemplo “test.log.1”.
Nuevo en la versión 3.3.
-
La razón de que existen los atributos es para evitar tener que usar una subclase - puedes usar los mismos invocadores para instancias de clase RotatingFileHandler
y TimedRotatingFileHandler
. Si el rotador invocable o la función de nombrado plantean una excepción esta se manejará de la misma manera que cualquier otra excepción durante una llamada al método emit()
por ejemplo a través del método handleError()
del gestor.
Si necesitas hacer cambios mas significativos al proceso de rotación puedes obviar los métodos.
Para un ejemplo véase Using a rotator and namer to customize log rotation processing.
RotatingFileHandler¶
La clase RotatingFileHandler
, localizada en el módulo logging.handlers
soporta la rotación de archivos log de disco.
-
class
logging.handlers.
RotatingFileHandler
(filename, mode='a', maxBytes=0, backupCount=0, encoding=None, delay=False)¶ Retorna una nueva instancia de la clase
RotatingFileHandler
. El archivo especificado es abierto y usado como un stream para logging. Si mode no se especifica , se usará'a'
. Si encoding no esNone
se usará para abrir el archivo con esa codificación. Si delay es verdadero entonces la apertura del archivo se diferirá hasta la primer llamada al métodoemit()
. Por defecto el archivo crece indefinidamente.Se pueden usar los valores maxBytes y backupCount para permitir que el archivo rollover tenga un tamaño predeterminado. Cuando el tamaño del archivo está a punto de excederse, se cerrará y un nuevo archivo se abrirá silenciosamente para salida. El volcado (rollover) ocurre cada vez que el actual archivo log esta cerca de maxBytes en tamaño , pero si cualquiera maxBytes o backupCount es cero, el volcado (rollover) no ocurre. Por eso generalmente necesitas establecer backupCount por lo menos en 1 y no tener cero en maxBytes. Cuando backupCount no es cero, el sistema guardará los anteriores archivos log agregando las extensiones “.1”, “.2” etc. al nombre del archivo. Por ejemplo con un backupCount de 5 y un nombre de archivo base de
app.log
, tendrás como nombre de archivo tapp.log
,app.log.1
,app.log.2
, hastaapp.log.5
. El archivo que esta siendo escrito es siempreapp.log
. Cuando este se completa , se cierra y se renombra aapp.log.1
y si ya existenapp.log.1
,app.log.2
, etc. Entonces se renombrará comoapp.log.2
,app.log.3
etc. respectivamente.Distinto en la versión 3.6: Así como valores de cadena de caracteres, también se aceptan objetos de la clase
Path
para el argumento «filename».-
doRollover
()¶ Realiza un volcado (rollover) como se describe arriba.
-
emit
(record)¶ Da la salida del registro al archivo , dando suministro para el volcado (rollover) como está descripto anteriormente.
-
TimedRotatingFileHandler¶
La clase TimedRotatingFileHandler
está ubicada en el módulo logging.handlers
. Soporta la rotación de archivos de log a ciertos intervalos de tiempo.
-
class
logging.handlers.
TimedRotatingFileHandler
(filename, when='h', interval=1, backupCount=0, encoding=None, delay=False, utc=False, atTime=None)¶ Retorna una nueva instancia de la clase
TimedRotatingFileHandler
. El archivo especificado es abierto y usado como stream para el historial de log. En la rotación también establece el sufijo del nombre de archivo. La rotación ocurre basada en el producto de when y interval.Puedes usar el when para especificar el tipo de intervalo interval. La lista de posibles valores esta debajo. Nota que no distingue mayúsculas y minúsculas.
Valor
Tipo de intervalo
Si/como atTime es usado
'S'
Segundos
Ignorado
'M'
Minutos
Ignorado
'H'
Horas
Ignorado
'D'
Días
Ignorado
'W0'-'W6'
Día de la semana (0=Lunes)
Usado para calcular la hora inicial del volcado rollover
'midnight'
Volcado (rollover) a medianoche , si atTime no está especificado, sino el volcado se hará atTime
Usado para calcular la hora inicial del volcado rollover
Cuando se usa rotación basada en día de la semana, especifica “W0” para Lunes, “W1” para Martes y así, hasta “W6” para Domingo. en este caso el valor pasado para Interval no se usa.
El sistema guardará los archivos de log anteriores agregándoles extensiones al nombre de archivo. Las extensiones están basadas en día-hora usando el formato
%Y-%m-%d_%H-%M-%S
o un prefijo respecto el intervalo del volcado (rollover).Cuando se calcula la hora del siguiente volcado (rollover) por primera vez (cuando el gestor es creado), la última hora de modificación de un archivo log existente o sino la hora actual, se usa para calcular cuando será la próxima rotación.
Si el argumento utc es true se usará la hora en UTC, sino se usará la hora local.
Si backupCount no es cero, se conservará como máximo una cantidad de archivos especificada en backupCount,y si son creados más, cuando ocurre el volcado (rollover) se borrará el último. La lógica de borrado usa el intervalo para determinar que archivos borrar, pues entonces cambiando el intervalo puede dejar viejos archivos abandonados.
Si delay es true entonces la apertura del archivo se demorará hasta la primer llamada a
emit()
.Si atTime no es «None», debe haber una instancia
datetime.time
que especifica la hora que ocurre el volcado (rollover) , para los casos en que el volcado esta establecido para ocurrir «a medianoche» o «un día en particular». Nótese que en estos casos el valor atTime se usa para calcular el valor initial del volcado (rollover) y los subsecuentes volcados serán calculados a través del calculo normal de intervalos.Nota
El cálculo de la hora en que se realizara el volcado (rollover) inicial cuando se inicializa el gestor. El cálculo de la hora de los siguientes volcados (rollovers) se realiza solo cuando este ocurre, y el volcado ocurre solo cuando se emite una salida. Si esto no se tiene en cuenta puede generar cierta confusión. Por ejemplo si se establece un intervalo de «cada minuto» eso no significa que siempre se verán archivos log con hora (en el nombre del archivo) separados por un minuto. Si durante la ejecución de la aplicación el logging se genera con mayor frecuencia que un minuto entonces se pueden esperar archivos log separados por un minuto. Si por otro lado los mensajes logging son establecidos cada digamos cinco minutos, entonces habrá brechas de tiempo en los archivos correspondientes a los minutos que no hubo salida (y no ocurrió por tanto volcado alguno).
Distinto en la versión 3.4: Se agregó el parámetro atTime.
Distinto en la versión 3.6: Así como valores de cadena de caracteres, también se aceptan objetos de la clase
Path
para el argumento «filename».-
doRollover
()¶ Realiza un volcado (rollover) como se describe arriba.
-
emit
(record)¶ Da la salida del registro a un archivo , proveyendo la información para el volcado (rollover) como esta descripto anteriormente.
-
SocketHandler¶
La clase SocketHandler
esta localizada en el módulo logging.handlers
, envía el logging a un socket de la red. La clase base usa sockets TCP.
-
class
logging.handlers.
SocketHandler
(host, port)¶ Retorna una nueva instancia de la clase
SocketHandler
destinada para comunicarse con una terminal remota cuya dirección esta dada por host y port.Distinto en la versión 3.4: Si «port» se especifica como``None`` se crea un socket de dominio Unix, usando el valor en``host`` - de otra manera se creará un socket TCP.
-
close
()¶ Cierra el socket.
-
emit
()¶ Serializa (Pickles) el registro del diccionario de atributos y lo escribe en el socket en formato binario. Si hay un error con el socket, silenciosamente descarta el paquete. Si la conexión se perdió previamente, la restablece. Para deserializar (unpickle) un registro en el extremo receptor a una clase
LogRecord
, usa la funciónmakeLogRecord()
.
-
handleError
()¶ Maneja un error que ocurrió durante el método
emit()
. La causa mas común es una perdida de conexión. Cierra el socket para que podamos reintentar en el próximo evento.
-
makeSocket
()¶ Este es un método patrón que permite subclases para definir el tipo preciso de socket que se necesita. La implementación por defecto crea un socket TCP(
socket.SOCK_STREAM
).
-
makePickle
(record)¶ Serializa (pickles) el registro del diccionario de atributos en formato binario con un prefijo de tamaño, y lo retorna listo para transmitir a través del socket. Los detalles de esta operación son equivalentes a:
data = pickle.dumps(record_attr_dict, 1) datalen = struct.pack('>L', len(data)) return datalen + data
Nota que los serializados (pickles) no son totalmente seguros. Si te preocupa la seguridad desearás evitar este método para implementar un mecanismo mas seguro. Por ejemplo puedes firmar pickles usando HMAC y verificarlos después en el extremo receptor. O alternativamente puedes deshabilitar la deserialización (unpickling) de objetos globales en el extremo receptor.
-
send
(packet)¶ Envía un paquete serializado (pickled) de cadena de caracteres al socket. El formato de la cadena de bytes enviada es tal como se describe en la documentación de
makePickle()
.Esta función permite envíos parciales, que pueden ocurrir cuando la red esta ocupada.
-
createSocket
()¶ Intenta crear un socket, si hay una falla usa un algoritmo de marcha atrás exponencial. En el fallo inicial el gestor desechará el mensaje que intentaba enviar. Cuando los siguientes mensajes sean gestionados por la misma instancia no intentará conectarse hasta que haya transcurrido cierto tiempo. Los parámetros por defecto son tales que el retardo inicial es un segundo y si después del retardo la conexión todavía no se puede realizar, el gestor doblará el retardo cada vez hasta un máximo de 30 segundos.
Este comportamiento es controlado por los siguientes atributos del gestor:
retryStart
(retardo inicial por defecto 1.0 segundos)retryFactor
(multiplicador por defecto 2.0)retryMax
(máximo retardo por defecto 30.0 segundos)
Esto significa que si el oyente remoto (listener) comienza después de que se usó el gestor , pueden perderse mensajes (dado que el gestor no puede siquiera intentar una conexión hasta que se haya cumplido el retardo, y silenciosamente desechará los mensajes mientras se cumpla el retardo).
-
DatagramHandler¶
La clase DatagramHandler
está ubicada en el módulo logging.handlers
, hereda de la clase SocketHandler
para realizar el soporte de mensajes logging por los sockets UDP.
-
class
logging.handlers.
DatagramHandler
(host, port)¶ Retorna una nueva instancia de la clase
DatagramHandler
destinada para comunicarse con la terminal remota cuya dirección es dada por host y port.Distinto en la versión 3.4: Si “port” se especifica como «None», se crea un socket de dominio Unix, usando el valor en «host» - de otra manera se crea un socket UDP.
-
emit
()¶ Serializa (pickles) el registro del diccionario de atributos y lo escribe en el socket en formato binario. Si hay un error con el socket, silenciosamente desecha el paquete. Para deserializar (unpickle) el registro en el extremo de recepción a una clase
LogRecord
, usa la funciónmakeLogRecord()
.
-
makeSocket
()¶ El método original de la clase
SocketHandler
se omite para crear un socket UDP (socket.SOCK_DGRAM
).
-
send
(s)¶ Enviar una cadena de caracteres serializada (pickled) a un socket de red. El formato de la cadena de bytes enviado es tal como se describe en la documentación para
SocketHandler.makePickle()
.
-
Gestor SysLog (SysLogHandler)¶
La clase SysLogHandler
está ubicada en el módulo logging.handlers
. Realiza el soporte de los mensajes de logging a un syslog Unix local o remoto.
-
class
logging.handlers.
SysLogHandler
(address=('localhost', SYSLOG_UDP_PORT), facility=LOG_USER, socktype=socket.SOCK_DGRAM)¶ Retorna una nueva instancia de la clase
SysLogHandler
concebida para comunicarse con una terminal remota Unix cuya dirección esta dada por address en la forma de una tupla(host, port)
. Si address no se especifica se usará('localhost', 514)
. La dirección se usa para abrir el socket. Una alternativa a consignar una tupla(host, port)
es proveer una dirección como cadena de caracteres, por ejemplo “/dev/log”. En este caso se usa un socket de dominio Unix para enviar el mensaje al syslog. Si facility no se especifica se usaraLOG_USER
. El tipo de socket abierto usado depende del argumento socktype , que por defecto essocket.SOCK_DGRAM
y por lo tanto abre un socket UDP . Para abrir un socket TCP (para usar con los nuevos daemons syslog como Rsyslog) se debe especificar un valor desocket.SOCK_STREAM
.Nótese que si el servidor no esta escuchando el puerto UDP 514, la clase
SysLogHandler
puede parecer no funcionar. En ese caso chequea que dirección deberías usar para un socket de dominio . Es sistema-dependiente. Por ejemplo en Linux generalmente es “/dev/log” pero en OS/X es “/var/run/syslog”. Será necesario chequear tu plataforma y usar la dirección adecuada (quizá sea necesario realizar este chequeo mientras corre la aplicación si necesita correr en diferentes plataformas). En Windows seguramente tengas que usar la opción UDP.Distinto en la versión 3.2: Se agregó socktype.
-
close
()¶ Cierra el socket del host remoto.
-
emit
(record)¶ El registro es formateado, y luego enviado al servidor syslog. Si hay información de excepción presente entonces no se enviará al servidor.
Distinto en la versión 3.2.1: (Véase el bpo-12168.) En versiones anteriores , los mensajes enviados a los daemons syslog siempre terminaban con un byte NUL ya que versiones anteriores de estos daemons esperaban un mensaje NUL de terminación. Incluso a pesar que no es relevante la especificación (RFC 5424). Versiones mas recientes de estos daemons no esperan el byte NUL pero lo quitan si esta ahí. Versiones aún mas recientes que están mas cercanas a la especificación RFC 5424 pasan el byte NUL como parte del mensaje.
Para habilitar una gestión mas sencilla de los mensajes syslog respecto de todos esos daemons de diferentes comportamientos el agregado del byte NUL es configurable a través del uso del atributo de nivel de clase “append_nul”. Este es por defecto “
True
(preservando el comportamiento ya existente) pero se puede establecer a “False” en una instanciaSysLogHandler
como para que esa instancia no añada el terminador NUL.Distinto en la versión 3.3: (Véase: issue “12419”) en versiones anteriores, no había posibilidades para un prefijo “ident” o “tag” para identificar el origen del mensaje. Esto ahora se puede especificar usando un atributo de nivel de clase, que por defecto será «””» para preservar el comportamiento existente , pero puede ser sorteado en una instancia
SysLogHandler
para que esta instancia anteponga el ident a todos los mensajes gestionados. Nótese que el ident provisto debe ser texto, no bytes y se antepone al mensaje tal como es.
-
encodePriority
(facility, priority)¶ Codifica la funcionalidad y prioridad en un entero. Puedes pasar cadenas de caracteres o enteros, si pasas cadenas de caracteres se usarán los diccionarios de mapeo interno para convertirlos en enteros.
Los valores simbólicos
LOG_
están definidos enSysLogHandler
e invierten los valores definidos en el archivo de encabezado sys/syslog.h`.Prioridades
Nombre (cadena de caracteres)
Valor simbólico
alert
LOG_ALERT
crit
orcritical
LOG_CRIT
debug
LOG_DEBUG
emerg
orpanic
LOG_EMERG
err
orerror
LOG_ERR
info
LOG_INFO
notice
LOG_NOTICE
warn
orwarning
LOG_WARNING
Facilities
Nombre (cadena de caracteres)
Valor simbólico
auth
LOG_AUTH
authpriv
LOG_AUTHPRIV
cron
LOG_CRON
daemon
LOG_DAEMON
ftp
LOG_FTP
kern
LOG_KERN
lpr
LOG_LPR
mail
LOG_MAIL
news
LOG_NEWS
syslog
LOG_SYSLOG
user
LOG_USER
uucp
LOG_UUCP
local0
LOG_LOCAL0
local1
LOG_LOCAL1
local2
LOG_LOCAL2
local3
LOG_LOCAL3
local4
LOG_LOCAL4
local5
LOG_LOCAL5
local6
LOG_LOCAL6
local7
LOG_LOCAL7
-
mapPriority
(levelname)¶ Mapea un nombre de nivel logging a un nombre de prioridad syslog. Puedes necesitar omitir esto si estas usando niveles personalizados, o si el algoritmo por defecto no es aplicable a tus necesidades. El algoritmo por defecto mapea
DEBUG
,INFO
,WARNING
,ERROR
yCRITICAL
a sus nombres equivalentes syslog, y todos los demás nombres de nivel a “warning”.
-
Gestor de eventos NTELog (NTEventLogHandler)¶
La clase NTEventLogHandler
esta localizada en el módulo logging.handlers
, soporta el envío de mensajes de logging a un log de eventos local Windows NT, Windows 2000 o Windows XP. Antes de que puedas usarlo, necesitarás tener instaladas las extensiones de Win32 de Mark Hammond para Python.
-
class
logging.handlers.
NTEventLogHandler
(appname, dllname=None, logtype='Application')¶ Retorna una nueva instancia de la clase
NTEventLogHandler
la appname se usa para definir el nombre de la aplicación tal como aparece en el log de eventos. Se crea una entrada de registro apropiada usando este nombre. El dllname debe dar la ruta completa calificada de un .dll o .exe que contiene definiciones de mensaje para conservar en el log. (si no esta especificada, se usara``”win32service.pyd”`` esto es instalado con las extensiones de Win32 y contiene algunas definiciones básicas de mensajes de conservación de lugar. Nótese que el uso de estos conservadores de lugar harán tu log de eventos extenso, dado que el origen completo del mensaje es guardado en el log. Si quieres logs menos extensos deberás pasar el nombre de tu propio .dll o .exe que contiene la definición de mensajes que quieres usar en el log. El logtype puede ser de'Application'
,'System'
or'Security'
y sino por defecto será de'Application'
.-
close
()¶ Llegado a este punto puedes remover el nombre de aplicación del registro como origen de entrada de log de eventos. Sin embargo si haces esto no te será posible ver los eventos tal como has propuesto en el visor del log de eventos - necesita ser capaz de acceder al registro para tomar el nombre .dll. Esto no lo hace la versión actual.
-
emit
(record)¶ Determina el ID del mensaje, categoría y tipo de evento y luego registra el mensaje en el log de eventos NT.
-
getEventCategory
(record)¶ Retorna la categoría de evento del registro. Evita esto si quieres especificar tus propias categorías. Esta versión retorna 0.
-
getEventType
(record)¶ Retorna el tipo de evento del registro. Haz caso omiso de esto si quieres especificar tus propios tipos. Esta versión realiza un mapeo usando el atributo typemap del gestor, que se establece en
__init__()
a un diccionario que contiene mapeo paraDEBUG
,INFO
,WARNING
,ERROR
yCRITICAL
. Si estas usando tus propios niveles, necesitarás omitir este método o colocar un diccionario a medida en el atributo typemap del gestor.
-
getMessageID
(record)¶ Retorna el ID de mensaje para el registro. Si estas usando tus propios mensajes, podrás hacerlo pasando el msg al logger siendo un ID mas que un formato de cadena de caracteres. Luego aquí puedes usar una búsqueda de diccionario para obtener el ID de mensaje. Esta versión retorna 1, que es el ID de mensaje base en
win32service.pyd
.
-
SMTPHandler¶
La clase SMTPHandler
esta ubicada en el módulo logging.handlers
y soporta el envío de mensajes de logging a un a dirección de correo electrónico a través de SMTP.
-
class
logging.handlers.
SMTPHandler
(mailhost, fromaddr, toaddrs, subject, credentials=None, secure=None, timeout=1.0)¶ Retorna una nueva instancia de la clase
SMTPHandler
. Esta instancia se inicializa con la dirección de: y para: y asunto: del correo electrónico. El toaddrs debe ser una lista de cadena de caracteres. Para especificar un puerto SMTP no estandarizado usa el formato de tupla (host, puerto) para el argumento mailhost. Si usas una cadena de caracteres, se utiliza el puerto estándar SMTP. Si tu servidor SMTP necesita autenticación, puedes especificar una tupla (usuario, contraseña) para el argumento de credentials.Para especificar el uso de un protocolo de seguridad (TLS), pasa una tupla al argumento secure. Esto solo se utilizará cuando sean provistas las credenciales de autenticación. La tupla deberá ser una tupla vacía o una tupla con único valor con el nombre de un archivo-clave keyfile, o una tupla de 2 valores con el nombre del archivo-clave keyfile y archivo certificado. (Esta tupla se pasa al método
smtplib.SMTP.starttls()
method.).Se puede especificar un tiempo de espera para comunicación con el servidor SMTP usando el argumento timeout.
Nuevo en la versión 3.3: Se agregó el argumento timeout.
-
emit
(record)¶ Formatea el registro y lo envía a las direcciones especificadas.
-
getSubject
(record)¶ Si quieres especificar una línea de argumento que es registro-dependiente, sobrescribe (override) este método.
-
MemoryHandler¶
La clase MemoryHandler
esta ubicada en el módulo logging.handlers
.Soporta el almacenamiento temporal de registros logging en memoria. Periódicamente los descarga al gestor target. Esto ocurre cuando el búfer está lleno o cuando ocurre un evento de cierta importancia.
MemoryHandler
es una subclase de la clase mas general BufferingHandler
, que es una clase abstracta. Este almacena temporalmente registros logging en la memoria. Cada vez que un registro es agregado al búfer, se realiza una comprobación llamando al método shouldFlush()
para ver si dicho búfer debe ser descargado. Si debiera, entonces el método flush()
se espera que realice la descarga.
-
class
logging.handlers.
BufferingHandler
(capacity)¶ Inicializa el gestor con un búfer de una capacidad especifica. Aquí capacidad significa el número de registros logging en el almacenamiento temporal.
-
emit
(record)¶ Añade un registro al búfer. Si el método
shouldFlush()
retorna true , entonces llama al métodoflush()
para procesar el búfer.
-
flush
()¶ Puedes sobrescribir (override) esto para implementar un comportamiento “a medida” de la descarga. Esta versión solo vacía el búfer.
-
shouldFlush
(record)¶ Retorna
True
si el búfer tiene aún capacidad. Este método puede ser omitido para implementar estrategias a medida de vaciado.
-
-
class
logging.handlers.
MemoryHandler
(capacity, flushLevel=ERROR, target=None, flushOnClose=True)¶ Retorna una nueva instancia de la clase
MemoryHandler
. La instancia se inicializa con un búfer del tamaño capacity. Si el flushLevel no se especifica, se usaráERROR
. Si no se especifica target el objetivo deberá especificarse usando el métodosetTarget()
-Antes de esto el gestor no realizará nada útil. Si se especifica flushOnClose comoFalse
, entonces el búfer no se vaciará cuando el gestor se cierra. Si no se especifica o se especifica comoTrue
, el comportamiento previo de vaciado del búfer sucederá cuando se cierre el gestor.Distinto en la versión 3.6: Se añadió el parámetro flushOnClose.
-
flush
()¶ Para la clase
MemoryHandler
el vaciado significa simplemente enviar los registros del búfer al objetivo, si es que hay uno. El búfer además se vacía cuando esto ocurre. Sobrescribe (override) si deseas un comportamiento diferente.
-
setTarget
(target)¶ Establece el gestor de objetivo para este gestor.
-
shouldFlush
(record)¶ Comprueba si el búfer esta lleno o un registro igual o mas alto que flushLevel.
-
HTTPHandler¶
La clase HTTPHandler
está ubicada en el módulo logging.handlers
.Soporta el envío de mensajes logging a un servidor Web, usando la semántica GET
o POST`.
-
class
logging.handlers.
HTTPHandler
(host, url, method='GET', secure=False, credentials=None, context=None)¶ Retorna una nueva instancia de la clase
HTTPHandler
. el host puede ser de la forma «host:puerto», y necesitarás usar un numero de puerto especifico. Si no se especifica method se usaráGET
. Si secure es true se usará una conexión HTTPS. El parámetro context puede establecerse a una instanciassl.SSLContext
para establecer la configuración de SSL usado en la conexión HTTPS. Si se especifica credentials debe ser una tupla doble, consistente en usuario y contraseña, que se colocará en un encabezado de autorización HTTP usando autenticación básica. Si especificas credenciales también deberás especificar secure=True así tu usuario y contraseña no son pasados como texto en blanco por la conexión.Distinto en la versión 3.5: Se agregó el parámetro context.
-
mapLogRecord
(record)¶ Provee un diccionario, basado en
record
para ser codificado en forma URL y enviado al servidor web. La implementación por defecto retornarecord.__dict__
. Este método puede omitirse si por ejemplo solo se enviará al servidor web un subconjunto de la claseLogRecord
o si se requiere enviar al servidor algo mas específico.
-
emit
(record)¶ Envía el registro al servidor Web como un diccionario con codificación URL. Se usa el método
mapLogRecord()
para convertir el registro al diccionario que debe ser enviado.
Nota
Dado que preparar un registro para enviar a un servidor Web no es lo mismo que una operación genérica de formato, usando el método
setFormatter()
para especificar una claseFormatter
por una claseHTTPHandler
no tiene efecto. En vez de llamar al métodoformat()
este gestor llama al métodomapLogRecord()
y después a la funciónurllib.parse.urlencode()
para codificar el diccionario en una forma que sea adecuada para enviar a un servidor Web.-
QueueHandler¶
Nuevo en la versión 3.2.
La clase QueueHandler
localizada en el módulo logging.handlers
soporta el envío de mensajes de logging a una cola, tal como los implementados en los módulos queue
o multiprocessing
.
Junto con la clase QueueListener
la clase QueueHandler
puede usarse para permitir a los gestores realizar su tarea en un hilo separado del que realiza el logging. Esto es importante en aplicaciones Web y también otras aplicaciones donde los clientes servidos por los hilos necesitan responder tan rápido como sea posible, mientras que cualquier operación potencialmente lenta (tal como enviar un correo electrónico a través la clase SMTPHandler
) se realizan por un hilo diferente.
-
class
logging.handlers.
QueueHandler
(queue)¶ Retorna una nueva instancia de la clase
QueueHandler
. La instancia se inicializa con la cola a la que se enviarán los mensajes. La cola puede ser cualquier objeto tipo-cola; es usado tal como por el métodoenqueue()
que necesita saber como enviar los mensajes a ella. La cola no es requerida para tener una API de rastreo de tareas, lo que significa que puedes usar instancias deSimpleQueue
como queue.-
emit
(record)¶ Pone en la cola el resultado de preparar el registro historial de log. Si ocurre una excepción (por ejemplo por que una cola de destino se llenó) entonces se llama al método
handleError()
. Esto puede resultar en que el registro se descarte (silogging.raiseExceptions
esFalse
) o que se imprima un mensaje asys.stderr
(silogging.raiseExceptions
esTrue
).
-
prepare
(record)¶ Prepara un registro para poner en la cola. El objeto que retorna este método se colocará en cola.
La implementación base da formato al registro para unir la información de los mensajes, argumentos y excepciones, si están presentes. También remueve los elementos que no se pueden serializar (unpickleables) de los registros in-situ.
Puedes querer hacer caso omiso de este método si quieres convertir el registro en un diccionario o cadena de caracteres JSON, o enviar una copia modificada del registro mientras dejas el original intacto.
-
enqueue
(record)¶ Coloca en la cola al registro usando
put_nowait()
; puede que quieras sobrescribe (override) esto si quieres usar una acción de bloqueo, o un tiempo de espera, o una implementación de cola a medida.
-
QueueListener¶
Nuevo en la versión 3.2.
La clase QueueListener
esta localizada en el módulo logging.handlers
. Soporta la recepción de mensajes logging de una cola, tal como los implementados en los módulos queue
or multiprocessing
. Los mensajes son recibidos de una cola en un hilo interno y se pasan en el mismo hilo, a uno o mas gestores para procesarlos. Mientras la clase QueueListener
no es en si misma un gestor, esta documentada aquí porque trabaja mano a mano con la clase QueueHandler
.
Junto con la clase QueueHandler
, la clase QueueListener
puede usarse para permitir a los gestores hacer su labor en un hilo separado del que hace el logging. Esto es importante en aplicaciones Web y también otras aplicaciones de servicio donde los clientes servidos por los hilos necesitan una respuesta tan rápida como sea posible, mientras cualquier operación potencialmente lenta (tal como enviar un correo electrónico a través de la clase SMTPHandler
) son atendidas por un hilo diferente.
-
class
logging.handlers.
QueueListener
(queue, *handlers, respect_handler_level=False)¶ Retorna una nueva instancia de la clase
QueueListener
. La instancia se inicializa con la cola para enviar mensajes a una lista de gestores que manejarán entradas colocadas en la cola. La cola puede ser cualquier objeto de tipo-cola, es usado tal como está por el métododequeue()
que necesita saber como tomar los mensajes de esta. La cola no es obligatoria para tener la API de seguimiento de tareas (aunque se usa si está disponible), lo que significa que puede usar instanciasSimpleQueue
para queue.Si
respect_handler_level
esTrue
, se respeta un nivel de gestor (comparado con el nivel del mensaje) cuando decide si pasar el mensajes al gestor; de otra manera, el comportamiento es como en versiones anteriores de Python - de pasar cada mensaje a cada gestor.Distinto en la versión 3.5: Se agregó el argumento
respect_handler_levels
.-
dequeue
(block)¶ Extrae de la cola un registro y lo retorna, con opción a bloquearlo.
La implementación base usa
get()
. Puedes sobrescribir (override) este método si quieres usar tiempos de espera o trabajar con colas implementadas a medida.
-
prepare
(record)¶ Prepara un registro para ser gestionado.
Esta implementación solo retorna el registro que fue pasado. Puedes sobrescribir (override) este método para hacer una serialización a medida o una manipulación del registro antes de pasarlo a los gestores.
-
handle
(record)¶ Manejar un registro.
Esto solo realiza un bucle a través de los gestores ofreciéndoles el registro para ser gestionado. El objeto actual pasado a los gestores es aquel que es retornado por el método
prepare()
.
-
start
()¶ Da comienzo al oyente (listener).
Esto da comienzo a un hilo en segundo plano para supervisar la cola de registros log a procesar.
-
stop
()¶ Detiene el oyente (listener).
Esto solicita terminar al hilo, y luego espera hasta que termine. Nota que si no llamas a esto antes de que tu aplicación salga, puede haber algunos registros que aun están en la cola, que no serán procesados.
-
enqueue_sentinel
()¶ Escribe un centinela (sentinel) en la cola para decir al oyente (listener) de salir. Esta implementación usa
put_nowait()
. Puedes sobrescribir (override) este método si quieres usar tiempos de espera o trabajar con implementaciones de cola a tu medida.Nuevo en la versión 3.3.
-
Ver también
- Módulo
logging
Referencia API para el módulo de logging.
- Módulo
logging.config
Configuración API para el módulo de logging.