Python logging handlers that send messages in the Graylog Extended Log Format (GELF).
Python logging handlers that send log messages in the Graylog Extended Log Format (GELF).
graypy supports sending GELF logs to both Graylog2 and Graylog3 servers.
Install the basic graypy python logging handlers:
Install with requirements for GELFRabbitHandler:
Install the basic graypy python logging handlers:
Install with requirements for GELFRabbitHandler:
graypy sends GELF logs to a Graylog server via subclasses of the python logging.Handler class.
Below is the list of ready to run GELF logging handlers defined by graypy:
UDP Log forwarding to a locally hosted Graylog server can be easily done with the GELFUDPHandler:
GELF UDP Chunking is supported by the GELFUDPHandler and is defined by the gelf_chunker argument within its constructor. By default the GELFWarningChunker is used, thus, GELF messages that chunk overflow (i.e. consisting of more than 128 chunks) will issue a GELFChunkOverflowWarning and will be dropped.
Other gelf_chunker options are also available:
Alternately, use GELFRabbitHandler to send messages to RabbitMQ and configure your Graylog server to consume messages via AMQP. This prevents log messages from being lost due to dropped UDP packets (GELFUDPHandler sends messages to Graylog using UDP). You will need to configure RabbitMQ with a gelf_log queue and bind it to the logging.gelf exchange so messages are properly routed to a queue that can be consumed by Graylog (the queue and exchange names may be customized to your liking).
It's easy to integrate graypy with Django's logging settings. Just add a new handler in your settings.py:
By default log captured exception tracebacks are added to the GELF log as full_message fields:
By default a number of debugging logging fields are automatically added to the GELF log if available:
- function
- pid
- process_name
- thread_name
You can disable automatically adding these debugging logging fields by specifying debugging_fields=False in the handler's constructor:
graypy also supports including custom fields in the GELF logs sent to Graylog. This can be done by using Python's LoggerAdapter and Filter classes.
LoggerAdapter makes it easy to add static information to your GELF log messages:
Filter gives more flexibility and allows for dynamic information to be added to your GELF logs:
- Sever Banesiu
- Daniel Miller
- Tushar Makkar
- Nathan Klapstein