JSON log formatting for the Python logging module.
Project description
jsonlog
A drop-in formatter for Python's logging module that outputs messages as line
delimited JSON.
While jsonlog provides it's own basicConfig method so you can get started
quickly, all of it's features and classes can be used with the logging module.
Usage
You can use jsonlog as a drop-in replacement for logging:
import jsonlog
jsonlog.warning("Hello world.")
{"timestamp": "2019-06-21T19:06:25.285730", "level": "WARNING", "name": "root", "message": "Hello world."}
It's implemented as a log formatter, so you can use logging just like you
normally would.
import jsonlog
import logging
jsonlog.basicConfig(level=jsonlog.INFO)
jsonlog.warning("Works with functions in the jsonlog module.")
logging.warning("And works with functions in the logging module.")
Configuration using jsonlog.basicConfig
The jsonlog.basicConfig function accepts slightly different parameters to
logging.basicConfig. It's shown here with the defaults for each parameter.
The filename, filemode and stream parameters work the same way as their
equivalents in logging.basicConfig, and as such filename and stream are
exclusive.
import jsonlog
jsonlog.basicConfig(
level=jsonlog.INFO,
indent=None,
keys=("timestamp", "level", "message"),
timespec="auto",
# filename=None,
# filemode="a",
# stream=None,
)
Configuration using logging.config.dictConfig
Any of the configuration methods in logging.config can be used to configure a
handler that uses jsonlog.formmatters.JSONFormatter to format records as JSON.
import logging.config
logging.config.dictConfig(
{
"version": 1,
"formatters": {"json": {"()": "jsonlog.JSONFormatter"}},
"handlers": {"stream": {"class": "logging.StreamHandler", "formatter": "json"}},
"loggers": {"": {"handlers": ["stream"]}},
}
)
Adding extra attributes to JSON output
Record attributes provided with extra= will be included in the JSON object.
import jsonlog
import logging
jsonlog.basicConfig()
logging.warning("User clicked a button", extra={"user": 123})
{"timestamp": "2019-06-21T19:06:54.293929", "level": "WARNING", "name": "root", "message": "User clicked a button", "user": 123}
If a mapping is passed as the only positional argument, attributes from the mapping will also be included.
import jsonlog
import logging
jsonlog.basicConfig()
logging.warning("User clicked a button", {"user": 123})
Pipelining
Try piping logs through jq if you want to read them on the command line!
python examples/hello.py 2> >(jq .)
{
"timestamp": "2019-06-21T19:07:43.211782",
"level": "WARNING",
"name": "root",
"message": "Hello world."
}
Tracebacks
Tracebacks are included as a single string - it's not very nice to read, but means it'll play nicely with any systems that read the JSON logs you output.
{"timestamp": "2019-06-21T19:08:37.326897", "level": "ERROR", "name": "root", "message": "Encountered an error", "traceback": "Traceback (most recent call last):\n File \"examples/error.py\", line 6, in <module>\n raise ValueError(\"Example exception\")\nValueError: Example exception"}
Tools like jq make it easy to extract and read the traceback:
python examples/error.py 2> >(jq -r ".traceback")
Traceback (most recent call last):
File "examples/error.py", line 6, in <module>
raise ValueError("Example exception")
ValueError: Example exception
Compatibility
jsonlog is written for Python 3.7 and above. Compatibility patches will be
accepted for Python 3.5 and above, but patches for Python 2 will be rejected.
References
Authors
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file jsonlog-2.0.0.tar.gz.
File metadata
- Download URL: jsonlog-2.0.0.tar.gz
- Upload date:
- Size: 9.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.7.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2f949de4ded2395e216274132622a90838685b2739b7101cfb84d6f097353219
|
|
| MD5 |
78120d1e2e2b4318d727325bb7cac8d1
|
|
| BLAKE2b-256 |
489f8399abf2f1ca7fc8ba7d215fb01efb986a9de464b7bac0bff9ca84c013df
|
File details
Details for the file jsonlog-2.0.0-py2.py3-none-any.whl.
File metadata
- Download URL: jsonlog-2.0.0-py2.py3-none-any.whl
- Upload date:
- Size: 10.9 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.7.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fbc92058553e7e3db007c3891ebdc969575f404a29e08ac86f794ad99606467a
|
|
| MD5 |
1a7fbf0dbb43de991e5dc927c04b937b
|
|
| BLAKE2b-256 |
9021020e9f82c1be362ae47e7de4551b89cb647f2f1d26879d6d41e303dbd798
|