Skip to main content

Optimized, opinionated structured logging for Python

Project description

containerlog

A lightweight, optimized, and opinionated structured logging library for Python, intended for containerized applications.

containerlog was born out of a desire to have high-quality structured logging for containerized applications (e.g. microservices) without having to compromise detailed logging for application/request latency.

structlog is a great general-purpose structured logging library for Python, but being general-purpose means that there is additional overhead when logging messages.

When we updated a microservice to use structured logging, we found that request latency went up, seemingly due to the transition to use structlog.

containerlog is not for everyone. It is highly opinionated, minimally configurable, and intentionally feature-sparse so that it can achieve better performance than the Python standard logger

Not every application needs optimized logging, but where latency and performance matters, containerlog could work for you.

timestamp='2020-07-23T13:11:28.009804Z' logger='my-logger' level='debug' event='loading configuration' path='./config.yaml'
timestamp='2020-07-23T13:11:28.010137Z' logger='my-logger' level='info' event='starting application'
timestamp='2020-07-23T13:11:28.010158Z' logger='my-logger' level='warn' event='having too much fun' countdown=[3, 2, 1]

Installation

containerlog can be installed with pip:

pip install containerlog

It is only intended to work for Python 3.6+.

Usage

See the documentation at https://containerlog.readthedocs.io/en/latest/

Optimizations

There are numerous sources discussion micro-optimizations in Python. This project probably does not implement them all, so there is room for improvement. Current optimization work has leveraged:

  • dis: to disassemble python bytecode for analysis
  • timeit: to measure execution time of code snippets

If you wish to contribute optimizations and use other libraries, tools, or sources, open a PR to add them to this list.

Benchmarks

Benchmarking scripts can be found in the benchmarks directory. To run,

$ cd benchmarks
$ ./run.sh

This will run benchmarks the Python standard logger and for containerlog. The latest results can be found below.

Results

Benchmarks were measured using Python 3.8.0 on macOS 10.15.1 with a 2.9 GHz 6-Core Intel Core i9 processor and 16 GB 2400 MHz DDR4 memory.

containerlog 0.3.0

Benchmark std logger (ns) std proxy (ns) containerlog (ns)
baseline 0.68 +/- 0.02 0.69 +/- 0.01 0.7 +/- 0.02
silent 108.0 +/- 6.0 1140.0 +/- 50.0 51.7 +/- 1.7
basic 4750.0 +/- 160.0 1140.0 +/- 60.0 1070.0 +/- 50.0
short-simple 5370.0 +/- 160.0 1280.0 +/- 60.0 1330.0 +/- 60.0
long-simple 5280.0 +/- 180.0 1480.0 +/- 70.0 2120.0 +/- 60.0
short-complex 5630.0 +/- 170.0 1500.0 +/- 150.0 1480.0 +/- 80.0
long-complex 6900.0 +/- 190.0 2870.0 +/- 80.0 3260.0 +/- 80.0
exception 10400.0 +/- 300.0 4440.0 +/- 150.0 4370.0 +/- 500.0

Contribute

While containerlog is intentionally feature-sparse, feature requests are welcome. Additionally, if you can find any other ways to micro-optimize the codebase, pull requests are very much appreciated.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

containerlog-0.4.2.tar.gz (24.3 kB view details)

Uploaded Source

Built Distribution

containerlog-0.4.2-py3-none-any.whl (24.3 kB view details)

Uploaded Python 3

File details

Details for the file containerlog-0.4.2.tar.gz.

File metadata

  • Download URL: containerlog-0.4.2.tar.gz
  • Upload date:
  • Size: 24.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.6 CPython/3.8.8 Linux/5.4.0-1036-gke

File hashes

Hashes for containerlog-0.4.2.tar.gz
Algorithm Hash digest
SHA256 bb18dbb6b7dd4dad6a51c307071d881f5dfc2470f1742e79fb18d749a325d671
MD5 ce893fc357256aed0577c37ea8e20c19
BLAKE2b-256 6bad988d88e54ecb903e4e4e7fbc1c1a2b4eb5766ab08f61c0a4adec95185609

See more details on using hashes here.

File details

Details for the file containerlog-0.4.2-py3-none-any.whl.

File metadata

  • Download URL: containerlog-0.4.2-py3-none-any.whl
  • Upload date:
  • Size: 24.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.6 CPython/3.8.8 Linux/5.4.0-1036-gke

File hashes

Hashes for containerlog-0.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 71f3b29aff051bbf290aba10e1d19e08587b659ebef6581a709a66cc4322aa9a
MD5 42be00b47a7ec96f00c2819b204d42a5
BLAKE2b-256 03906444eeb84930b76f7fb92425d80c27dc49ba325907345e7d34824e7a7787

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page