Skip to main content

Log without the setup via a pre-configured structlog logger with optional Sentry integration

Project description

Structlog-Sentry-Logger

CI codecov License PyPI - Python Version PyPI pre-commit Code style: black powered by semgrep


Documentation: https://structlog-sentry-logger.readthedocs.io

Source Code: https://github.com/TeoZosa/structlog-sentry-logger


:teacher: Overview

A multi-purpose, pre-configured, performance-optimized structlog logger with (optional) Sentry integration via structlog-sentry.

:sparkles: Features

  1. Makes logging as easy as using print statements, but prettier and easier to capture and filter!
  2. Highly opinionated! There are only two (2) distinct configurations.
  3. Structured logs in JSON format means they are ready to be ingested by many of your favorite log analysis tools!
  4. Cloud Logging compatible!

:confetti_ball: What You Get

:muscle: Powerful Automatic Context Fields

The pre-configured options include:

  1. :watch: Timestamps
    • UTC time in ISO 8601 format (YYYY-MM-DDTHH:MM:SS.ffffffZ)
  2. :vertical_traffic_light: Log levels
    • Added to the JSON context for filtering and categorization
  3. :mag: Logger names
    • Automatically assigned to namespaced versions of the initializing python modules (.py files), relative to your project directory.
      • e.g., the logger in docs_src/sentry_integration.py is named docs_src.sentry_integration
  4. :mag_right: Function names and line numbers where logging calls were made

With fields sorted by key for easier at-a-glance analysis.

:zap: Performance

structlog-sentry-logger is C-compiled and fully-tuned, leveraging orjson as the JSON serializer for lightning-fast logging (more than a 4x speedup over Python's built-in JSON library[^1]; see here for sample performance benchmarks). Don't let your obligate cross-cutting concerns cripple performance any longer!

For further reference, see:

[^1]: Source: Choosing a faster JSON library for Python: Benchmarking

:robot: Built-in Sentry Integration (Optional)

Automatically add much richer context to your Sentry reports.

  • Your entire logging context is sent as a Sentry event when the structlog-sentry-logger log level is error or higher.
    • i.e., logger.error(""), logger.exception("")
  • See structlog-sentry for more details.

Table of Contents

:tada: Installation

pip install structlog-sentry-logger

:rocket: Usage

:loud_sound: Pure structlog Logging (Without Sentry)

Simply import and instantiate the logger:

import structlog_sentry_logger

LOGGER = structlog_sentry_logger.get_logger()

Now you can start adding logs as easily as print statements:

LOGGER.info("Your log message", extra_field="extra_value")

:memo: Note
All the regular Python logging levels are supported.

Which automatically produces this:

{
    "event": "Your log message",
    "extra_field": "extra_value",
    "funcName": "<module>",
    "level": "info",
    "lineno": 5,
    "logger": "docs_src.pure_structlog_logging_without_sentry",
    "timestamp": "2022-01-11T07:05:37.164744Z"
}

:outbox_tray: Log Custom Context Directly to Sentry

Incorporate custom messages in your exception handling which will automatically be reported to Sentry (thanks to the structlog-sentry module). To enable this behavior, export the STRUCTLOG_SENTRY_LOGGER_CLOUD_SENTRY_INTEGRATION_MODE_ON environment variable.

An easy way to do this is to put it into a local .env file[^2]:

echo "STRUCTLOG_SENTRY_LOGGER_CLOUD_SENTRY_INTEGRATION_MODE_ON=" >> .env

For a concrete example, given the following Python code:

import uuid

import structlog_sentry_logger

LOGGER = structlog_sentry_logger.get_logger()

curr_user_logger = LOGGER.bind(uuid=uuid.uuid4().hex)  # LOGGER instance with bound UUID
try:
    curr_user_logger.warn("A dummy error for testing purposes is about to be thrown!")
    x = 1 / 0
except ZeroDivisionError as err:
    ERR_MSG = (
        "I threw an error on purpose for this example!\n"
        "Now throwing another that explicitly chains from that one!"
    )
    curr_user_logger.exception(ERR_MSG)
    raise RuntimeError(ERR_MSG) from err

We would get the following output:

{
    "event": "A dummy error for testing purposes is about to be thrown!\n",
    "funcName": "<module>",
    "level": "warning",
    "lineno": 12,
    "logger": "docs_src.sentry_integration",
    "sentry": "skipped",
    "timestamp": "2022-01-06T04:50:07.627633Z",
    "uuid": "fe2bdcbe2ed74432a87bc76bcdc9def4"
}
{
    "event": "I threw an error on purpose for this example!\nNow throwing another that explicitly chains from that one!\n",
    "exc_info": true,
    "funcName": "<module>",
    "level": "error",
    "lineno": 19,
    "logger": "docs_src.sentry_integration",
    "sentry": "sent",
    "sentry_id": null,
    "timestamp": "2022-01-06T04:50:07.628316Z",
    "uuid": "fe2bdcbe2ed74432a87bc76bcdc9def4"
}
Traceback (most recent call last):
  File "/app/structlog-sentry-logger/docs_src/sentry_integration.py", line 10, in <module>
    x = 1 / 0
ZeroDivisionError: division by zero

The above exception was the direct cause of the following exception:

Traceback (most recent call last):
  File "/app/structlog-sentry-logger/docs_src/sentry_integration.py", line 17, in <module>
    raise RuntimeError(ERR_MSG) from err
RuntimeError: I threw an error on purpose for this example!
Now throwing another that explicitly chains from that one!

:cloud: Cloud Logging Compatibility

The logger will attempt to infer if an application is running in a cloud environment by inspecting for the presence of environment variables that may be automatically injected by cloud providers (namely, KUBERNETES_SERVICE_HOST, GCP_PROJECT, and GOOGLE_CLOUD_PROJECT).

If any of these environment variables are detected, log levels will be duplicated to a reserved severity key in the emitted logs to enable parsing of the log level and the remaining log context (as jsonPayload) by Cloud Logging (see: Cloud Logging: Structured logging).

:memo: ️Note
This behavior can also be manually enabled by adding the STRUCTLOG_SENTRY_LOGGER_CLOUD_LOGGING_COMPATIBILITY_MODE_ON variable to your environment, e.g., via a .env file[^2].

:warning:️ Warning
If a user manually specifies a value for the severity key, it will be overwritten! Avoid using this key if possible to preempt any future issues.

:chart_with_downwards_trend: Output: Formatting & Storage

The default behavior is to stream JSON logs directly to the standard output stream like a proper 12 Factor App.

For local development, it often helps to prettify logging to stdout and save JSON logs to a .logs folder at the root of your project directory for later debugging. To enable this behavior, export the STRUCTLOG_SENTRY_LOGGER_LOCAL_DEVELOPMENT_LOGGING_MODE_ON environment variable, e.g., in your local .env file[^2]:

echo "STRUCTLOG_SENTRY_LOGGER_LOCAL_DEVELOPMENT_LOGGING_MODE_ON=" >> .env

In doing so, with our previous exception handling example we would get:

Output_Formatting_example_0 Output_Formatting_example_1

[^2]: This library uses python-dotenv to automatically populate your environment with this variable (if it exists) from the local .env file. Alternatively, you may use direnv and a .envrc file. A sample .envrc file (with all features enabled) has been provided at the root of the repository (.envrc.sample). If direnv is already installed, it's as simple as copying .envrc.sample to the root of your project, editing it to reflect your desired configurations, renaming it to .envrc, and running direnv allow :tada:

:clipboard: Summary

That's it. Now no excuses. Get out there and program with pride knowing no one will laugh at you in production! For not logging properly, that is. You're on your own for that other observability stuff.

:books: Further Reading

:one: structlog: Structured Logging for Python

:two: Sentry: Monitor and fix crashes in realtime

:three: structlog-sentry: Provides the structlog integration for Sentry


:wrench: Development

For convenience, implementation details of the below processes are abstracted away and encapsulated in single Make targets.

:fire: Tip
Invoking make without any arguments will display auto-generated documentation on available commands.

:building_construction: Package and Dependencies Installation

Make sure you have Python 3.7+ and poetry installed and configured.

To install the package and all dev dependencies, run:

make provision-environment

:fire: Tip
Invoking the above without poetry installed will emit a helpful error message letting you know how you can install poetry.

:package: Python Module to C-Extension Compilation

The projects's build.py file specifies which modules to package.

For manual per-module compilation, see: Mypyc Documentation: Getting started - Compiling and running

:white_check_mark: Testing

We use tox and pytest for our test automation and testing frameworks, respectively.

To invoke the tests, run:

make test

Run mutation tests to validate test suite robustness (Optional):

make test-mutations

:information_source: Technical Details
Test time scales with the complexity of the codebase. Results are cached in .mutmut-cache, so once you get past the initial cold start problem, subsequent mutation test runs will be much faster; new mutations will only be applied to modified code paths.

:rotating_light: Code Quality

We use pre-commit for our static analysis automation and management framework.

To invoke the analyses and auto-formatting over all version-controlled files, run:

make lint

:rotating_light: Danger
CI will fail if either testing or code quality fail, so it is recommended to automatically run the above locally prior to every commit that is pushed.

:arrows_counterclockwise: Automate via Git Pre-Commit Hooks

To automatically run code quality validation on every commit (over to-be-committed files), run:

make install-pre-commit-hooks

:warning:️ Warning
This will prevent commits if any single pre-commit hook fails (unless it is allowed to fail) or a file is modified by an auto-formatting job; in the latter case, you may simply repeat the commit and it should pass.

:memo: Documentation

make docs-clean docs-html

:fire: Tip
For faster feedback loops, this will attempt to automatically open the newly built documentation static HTML in your browser.

:judge: Legal

:page_facing_up: License

Structlog-Sentry-Logger is licensed under the Apache License, Version 2.0. See LICENSE for the full license text.

:busts_in_silhouette: Credits

This project was generated from @TeoZosa's cookiecutter-cruft-poetry-tox-pre-commit-ci-cd template.

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

structlog-sentry-logger-0.17.1.tar.gz (29.5 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

structlog_sentry_logger-0.17.1-cp39-cp39-win_amd64.whl (102.7 kB view details)

Uploaded CPython 3.9Windows x86-64

structlog_sentry_logger-0.17.1-cp39-cp39-manylinux_2_31_x86_64.whl (182.7 kB view details)

Uploaded CPython 3.9manylinux: glibc 2.31+ x86-64

structlog_sentry_logger-0.17.1-cp39-cp39-macosx_10_16_x86_64.whl (111.4 kB view details)

Uploaded CPython 3.9macOS 10.16+ x86-64

structlog_sentry_logger-0.17.1-cp38-cp38-win_amd64.whl (101.9 kB view details)

Uploaded CPython 3.8Windows x86-64

structlog_sentry_logger-0.17.1-cp38-cp38-manylinux_2_31_x86_64.whl (181.8 kB view details)

Uploaded CPython 3.8manylinux: glibc 2.31+ x86-64

structlog_sentry_logger-0.17.1-cp38-cp38-macosx_10_16_x86_64.whl (109.8 kB view details)

Uploaded CPython 3.8macOS 10.16+ x86-64

structlog_sentry_logger-0.17.1-cp37-cp37m-win_amd64.whl (100.6 kB view details)

Uploaded CPython 3.7mWindows x86-64

structlog_sentry_logger-0.17.1-cp37-cp37m-manylinux_2_31_x86_64.whl (155.1 kB view details)

Uploaded CPython 3.7mmanylinux: glibc 2.31+ x86-64

structlog_sentry_logger-0.17.1-cp37-cp37m-macosx_10_16_x86_64.whl (107.8 kB view details)

Uploaded CPython 3.7mmacOS 10.16+ x86-64

File details

Details for the file structlog-sentry-logger-0.17.1.tar.gz.

File metadata

  • Download URL: structlog-sentry-logger-0.17.1.tar.gz
  • Upload date:
  • Size: 29.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for structlog-sentry-logger-0.17.1.tar.gz
Algorithm Hash digest
SHA256 6aeace4126abd30ab4f8ecc0be6107748195e71edad60ad46955fccbf52fa0c5
MD5 7852ca65343b6f465dd17ac961ba137e
BLAKE2b-256 f00b6f4756dbcdc5aab89f9268ea1f4a992ae0e81f4453749c56c537f4712771

See more details on using hashes here.

File details

Details for the file structlog_sentry_logger-0.17.1-cp39-cp39-win_amd64.whl.

File metadata

  • Download URL: structlog_sentry_logger-0.17.1-cp39-cp39-win_amd64.whl
  • Upload date:
  • Size: 102.7 kB
  • Tags: CPython 3.9, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for structlog_sentry_logger-0.17.1-cp39-cp39-win_amd64.whl
Algorithm Hash digest
SHA256 707ced671b4736f9301aefb084577d7b9902fdd93703c14139786d4a8f4eeef2
MD5 b9e706cddc6ed6e0560c78f0f67e890f
BLAKE2b-256 2bd78e290ca408ada922e0d66b787b76710ed31bc321cf83bed3c3153d2f5325

See more details on using hashes here.

File details

Details for the file structlog_sentry_logger-0.17.1-cp39-cp39-manylinux_2_31_x86_64.whl.

File metadata

  • Download URL: structlog_sentry_logger-0.17.1-cp39-cp39-manylinux_2_31_x86_64.whl
  • Upload date:
  • Size: 182.7 kB
  • Tags: CPython 3.9, manylinux: glibc 2.31+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for structlog_sentry_logger-0.17.1-cp39-cp39-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 b5c4656796635f011f9606695942c3f855cd0d212ed6b5fd7979144d7b0bdda8
MD5 125f82a8fc5a810d429e3216f37bef14
BLAKE2b-256 74150832276172a9366b42c7663cc3f05345d7f867a4ac281df3fd6227759682

See more details on using hashes here.

File details

Details for the file structlog_sentry_logger-0.17.1-cp39-cp39-macosx_10_16_x86_64.whl.

File metadata

  • Download URL: structlog_sentry_logger-0.17.1-cp39-cp39-macosx_10_16_x86_64.whl
  • Upload date:
  • Size: 111.4 kB
  • Tags: CPython 3.9, macOS 10.16+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for structlog_sentry_logger-0.17.1-cp39-cp39-macosx_10_16_x86_64.whl
Algorithm Hash digest
SHA256 46db7854e40792e255ce37ae29d3ab21642d5b0b5f2e75a827893ed9df7f3624
MD5 677871d04fe00428f74b1b30d5128f16
BLAKE2b-256 84c3d35ca3b04a6ee687964b4604e1639c8c05b804a215f37233e68384594587

See more details on using hashes here.

File details

Details for the file structlog_sentry_logger-0.17.1-cp38-cp38-win_amd64.whl.

File metadata

  • Download URL: structlog_sentry_logger-0.17.1-cp38-cp38-win_amd64.whl
  • Upload date:
  • Size: 101.9 kB
  • Tags: CPython 3.8, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for structlog_sentry_logger-0.17.1-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 4f548d03d89f11ae09a702a5c554e93449feea1f372bde5290f7fb26a4123e22
MD5 1c37b51174f29714e4ab1b779103dc70
BLAKE2b-256 79229f465b6bcef05c2aea62ca0391f247d124c7e8524562550a032c00fb9ffc

See more details on using hashes here.

File details

Details for the file structlog_sentry_logger-0.17.1-cp38-cp38-manylinux_2_31_x86_64.whl.

File metadata

  • Download URL: structlog_sentry_logger-0.17.1-cp38-cp38-manylinux_2_31_x86_64.whl
  • Upload date:
  • Size: 181.8 kB
  • Tags: CPython 3.8, manylinux: glibc 2.31+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for structlog_sentry_logger-0.17.1-cp38-cp38-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 6ea80cffe3e1f47ebf672d215e0bbfd6bb2cc74a6712bb1ba8c68f8a363ba737
MD5 688df6a7e8334ee85801c5a0f8ba65ac
BLAKE2b-256 de421dacdf7957c04843920752a8cf9568fdecf502be1158c85ef908e2af21e0

See more details on using hashes here.

File details

Details for the file structlog_sentry_logger-0.17.1-cp38-cp38-macosx_10_16_x86_64.whl.

File metadata

  • Download URL: structlog_sentry_logger-0.17.1-cp38-cp38-macosx_10_16_x86_64.whl
  • Upload date:
  • Size: 109.8 kB
  • Tags: CPython 3.8, macOS 10.16+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for structlog_sentry_logger-0.17.1-cp38-cp38-macosx_10_16_x86_64.whl
Algorithm Hash digest
SHA256 d73fb946770fb961f8d25343f58141927985d9428020c5b89a3a4b098cd2a0f2
MD5 b1394c68fcd364cf13517a7484693b4b
BLAKE2b-256 b5515d05aaad71b2ca2d97cc11734605f022384dd9937656ab54bef5d956432a

See more details on using hashes here.

File details

Details for the file structlog_sentry_logger-0.17.1-cp37-cp37m-win_amd64.whl.

File metadata

  • Download URL: structlog_sentry_logger-0.17.1-cp37-cp37m-win_amd64.whl
  • Upload date:
  • Size: 100.6 kB
  • Tags: CPython 3.7m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for structlog_sentry_logger-0.17.1-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 7705ba65003c2425b3afa822e94e65de94752e5dc2ccdd587f17c2954845884a
MD5 600fa5702a58a8af5055f751f00a6982
BLAKE2b-256 7c839b0b6b81131ffd7cd53486b18430e6680ecf87f6720a1101773166b116f3

See more details on using hashes here.

File details

Details for the file structlog_sentry_logger-0.17.1-cp37-cp37m-manylinux_2_31_x86_64.whl.

File metadata

  • Download URL: structlog_sentry_logger-0.17.1-cp37-cp37m-manylinux_2_31_x86_64.whl
  • Upload date:
  • Size: 155.1 kB
  • Tags: CPython 3.7m, manylinux: glibc 2.31+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for structlog_sentry_logger-0.17.1-cp37-cp37m-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 0381225f544cc1f718d9f079b850f9069ea9bb5e86c07e0255062bb9776878d4
MD5 34de5a471929e415e06a2a3f16ccba18
BLAKE2b-256 919715eb3fffb30551e1ea1bb74d92e31b58f0a6c33bfdeca27fd54ae414f1e4

See more details on using hashes here.

File details

Details for the file structlog_sentry_logger-0.17.1-cp37-cp37m-macosx_10_16_x86_64.whl.

File metadata

  • Download URL: structlog_sentry_logger-0.17.1-cp37-cp37m-macosx_10_16_x86_64.whl
  • Upload date:
  • Size: 107.8 kB
  • Tags: CPython 3.7m, macOS 10.16+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for structlog_sentry_logger-0.17.1-cp37-cp37m-macosx_10_16_x86_64.whl
Algorithm Hash digest
SHA256 970d35f90f52ea87216fc750190a00e1e6474f9ab0007822b09872c3554b397e
MD5 f98ea9ac32e2626bebd6dd3179c30d5c
BLAKE2b-256 7247863f675d176e8868db30f52253c6204d2fa0f268cf79d90b30021444606d

See more details on using hashes here.

Supported by

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