This library is provided to allow standard python logging to output log data as json objects ready to be shipped out to logstash.
Pip (PyPI):
pip install logstash_formatter
Manual:
python setup.py install
Json outputs are provided by the LogstashFormatter logging formatter.
import logging from logstash_formatter import LogstashFormatterV1 logger = logging.getLogger() handler = logging.StreamHandler() formatter = LogstashFormatterV1() handler.setFormatter(formatter) logger.addHandler(handler)
The LogstashFormatter may take the following named parameters:
fmt: Config as a JSON string that supports:extra: provide extra fields always present in logs.source_host: override source host name.
json_cls: JSON encoder to forward tojson.dump.json_default: Default JSON representation for unknown types, by default coerce everything to a string.
LogstashFormatterV1 adheres to the more 1.2.0 schema and will not update
fields, apart from a special handling of msg which will be updated to
message when applicable.
You can also add extra fields to your json output by specifying a dict in place of message, or by specifying
the named argument extra as a dictionary. When supplying the exc_info named argument with a truthy value,
and if an exception is found on the stack, its traceback will be attached to the payload as well.
logger.info({"account": 123, "ip": "172.20.19.18"})
logger.info("classic message for account: {account}", extra={"account": account})
try:
h = {}
h['key']
except:
logger.info("something unexpected happened", exc_info=True)
The following keys will be found in the output JSON:
@source_host: source hostname for the log@timestamp: ISO 8601 timestamp@message: short message for this log@fields: all extra fields
{
"@fields": {
"account": "pyr",
"args": [],
"created": 1367480388.013037,
"exception": [
"Traceback (most recent call last):\n",
" File \"test.py\", line 16, in <module>\n k['unknown']\n",
"KeyError: 'unknown'\n"
],
"filename": "test.py",
"funcName": "<module>",
"levelname": "WARNING",
"levelno": 30,
"lineno": 18,
"module": "test",
"msecs": 13.036966323852539,
"name": "root",
"pathname": "test.py",
"process": 1819,
"processName": "MainProcess",
"relativeCreated": 18.002986907958984,
"thread": 140060726359808,
"threadName": "MainThread"
},
"@message": "TEST",
"@source_host": "phoenix.spootnik.org",
"@timestamp": "2013-05-02T09:39:48.013158"
}