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
    • DATETIME_FORMAT = "%Y-%m-%d %H:%M:%S"
  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

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)

At the top of your Python module, import and instantiate the logger:

import structlog_sentry_logger

LOGGER = structlog_sentry_logger.get_logger()

Now anytime you want to print anything, don't. Instead do this:

LOG_MSG = "Information that's useful for future me and others"
LOGGER.info(LOG_MSG, extra_field="extra_value")

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

Which automatically produces this:

{
    "event": "Information that's useful for future me and others",
    "extra_field": "extra_value",
    "level": "info",
    "logger": "docs_src.pure_structlog_logging_without_sentry",
    "sentry": "skipped",
    "timestamp": "2020-10-18 15:30:05"
}

:goal_net: Sentry Integration

Export your Sentry DSN into your local environment.

  • An easy way to do this is to put it into a local .env file*:
# On the command line:
SENTRY_DSN=YOUR_SENTRY_DSN
echo "SENTRY_DSN=${SENTRY_DSN}" >> .env

Then load the .env file in your Python code prior to instantiating the logger, e.g.:

import structlog_sentry_logger

LOGGER = structlog_sentry_logger.get_logger()

:outbox_tray: Log Custom Context Directly to Sentry

With structlog, you can even incorporate custom messages in your exception handling which will automatically be reported to Sentry (thanks to the structlog-sentry module):

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
{
    "event": "A dummy error for testing purposes is about to be thrown!",
    "level": "warning",
    "logger": "docs_src.sentry_integration",
    "sentry": "skipped",
    "timestamp": "2020-10-18 15:29:55",
    "uuid": "181e0e00b9034732af4fed2b8424fb11"
}
{
    "event": "I threw an error on purpose for this example!\nNow throwing another that explicitly chains from that one!",
    "exception": 'Traceback (most recent call last):\n  File "/app/structlog-sentry-logger/docs_src/sentry_integration.py", line 10, in <module>\n    x = 1 / 0\nZeroDivisionError: division by zero',
    "level": "error",
    "logger": "docs_src.sentry_integration",
    "sentry": "sent",
    "sentry_id": null,
    "timestamp": "2020-10-18 15:29:55",
    "uuid": "181e0e00b9034732af4fed2b8424fb11"
}
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*.

: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, set the following environment variable (assuming you are populating environment variables via a .env file*, as in the Sentry Integration section):

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

* This library uses [`python-dotenv`](https://github.com/theskumar/python-dotenv) to automatically populate your environment with this variable (if it exists)

: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.

: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


: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.12.2.tar.gz (27.9 kB view details)

Uploaded Source

Built Distributions

structlog_sentry_logger-0.12.2-cp39-cp39-win_amd64.whl (85.6 kB view details)

Uploaded CPython 3.9 Windows x86-64

structlog_sentry_logger-0.12.2-cp39-cp39-manylinux_2_31_x86_64.whl (330.0 kB view details)

Uploaded CPython 3.9 manylinux: glibc 2.31+ x86-64

structlog_sentry_logger-0.12.2-cp39-cp39-macosx_10_16_x86_64.whl (89.2 kB view details)

Uploaded CPython 3.9 macOS 10.16+ x86-64

structlog_sentry_logger-0.12.2-cp38-cp38-win_amd64.whl (84.7 kB view details)

Uploaded CPython 3.8 Windows x86-64

structlog_sentry_logger-0.12.2-cp38-cp38-manylinux_2_31_x86_64.whl (322.8 kB view details)

Uploaded CPython 3.8 manylinux: glibc 2.31+ x86-64

structlog_sentry_logger-0.12.2-cp38-cp38-macosx_10_16_x86_64.whl (88.1 kB view details)

Uploaded CPython 3.8 macOS 10.16+ x86-64

structlog_sentry_logger-0.12.2-cp37-cp37m-win_amd64.whl (84.5 kB view details)

Uploaded CPython 3.7m Windows x86-64

structlog_sentry_logger-0.12.2-cp37-cp37m-manylinux_2_31_x86_64.whl (299.8 kB view details)

Uploaded CPython 3.7m manylinux: glibc 2.31+ x86-64

structlog_sentry_logger-0.12.2-cp37-cp37m-macosx_10_16_x86_64.whl (87.2 kB view details)

Uploaded CPython 3.7m macOS 10.16+ x86-64

File details

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

File metadata

  • Download URL: structlog-sentry-logger-0.12.2.tar.gz
  • Upload date:
  • Size: 27.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for structlog-sentry-logger-0.12.2.tar.gz
Algorithm Hash digest
SHA256 3ca5876bf49fe379f0e602ec472334d464d5377f97b3ff387828fc0e526874c0
MD5 584fae474d55902d6433e5c654cacf19
BLAKE2b-256 828d0689e3ee63e3cad58faf5dfbff2b8773a40891ffd6d15984fce76154c84a

See more details on using hashes here.

File details

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

File metadata

  • Download URL: structlog_sentry_logger-0.12.2-cp39-cp39-win_amd64.whl
  • Upload date:
  • Size: 85.6 kB
  • Tags: CPython 3.9, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for structlog_sentry_logger-0.12.2-cp39-cp39-win_amd64.whl
Algorithm Hash digest
SHA256 28e078e785c2fbb5672cd62c538fb514693a3d6e2e16e9ed2f30b8c2ce71c59c
MD5 4a71dd48f4be2ea9f6953a54042812bf
BLAKE2b-256 987e1b7c3b5d0903b9c8090f2a10c71f15caad70355bc3ee94a79fd87b2325b7

See more details on using hashes here.

File details

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

File metadata

  • Download URL: structlog_sentry_logger-0.12.2-cp39-cp39-manylinux_2_31_x86_64.whl
  • Upload date:
  • Size: 330.0 kB
  • Tags: CPython 3.9, manylinux: glibc 2.31+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for structlog_sentry_logger-0.12.2-cp39-cp39-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 316385f3246b65d9a9b852c083a1dd2aa580ca9d627619179d4144e0b957b391
MD5 2a46fe551b42f3f0e1eb3063cf2e1e61
BLAKE2b-256 3dae3738f2b77ccbd3654b477ff913b7cc188efc0ca3e1b3ed4f7792349ea009

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for structlog_sentry_logger-0.12.2-cp39-cp39-macosx_10_16_x86_64.whl
Algorithm Hash digest
SHA256 b6416a96dc42bb958805ffd927ee8050ca774083996ec6a531196677a8f30194
MD5 993455aa0601b4205756a4ab2aac7951
BLAKE2b-256 3973016fae53a982c0981fd8b09bcb1df74eb2ecfc710ded445e6142bf5b90a7

See more details on using hashes here.

File details

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

File metadata

  • Download URL: structlog_sentry_logger-0.12.2-cp38-cp38-win_amd64.whl
  • Upload date:
  • Size: 84.7 kB
  • Tags: CPython 3.8, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for structlog_sentry_logger-0.12.2-cp38-cp38-win_amd64.whl
Algorithm Hash digest
SHA256 f5f959a526bd6cf3b16eaa37b99e23ef0c0bff83216ee010011eb59943be90ba
MD5 52bb7473fadd2731e16c35942c122c9c
BLAKE2b-256 ed843336135fc750fd6ffed372c1e9bd7f64e8439bc03d51e5855dc734461de7

See more details on using hashes here.

File details

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

File metadata

  • Download URL: structlog_sentry_logger-0.12.2-cp38-cp38-manylinux_2_31_x86_64.whl
  • Upload date:
  • Size: 322.8 kB
  • Tags: CPython 3.8, manylinux: glibc 2.31+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for structlog_sentry_logger-0.12.2-cp38-cp38-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 798c6386bb379dadace2c54b336e267e5aef724be9be74b0173f69945296c62c
MD5 aa0595a1c863c1bc80f14884fda9bc94
BLAKE2b-256 e582662a91519ce93a9b711a584fc416c4dbe8cdb864230bf2cd051f0ec484e0

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for structlog_sentry_logger-0.12.2-cp38-cp38-macosx_10_16_x86_64.whl
Algorithm Hash digest
SHA256 a03602094423c563c6de169fa538b35af03c323f5504edae9057e6c5bbff4adc
MD5 9e42d0878ccb55b290a7b957ab910b24
BLAKE2b-256 c7033b2b48c0acaa58571efcfddd2eae9d7831112e120835101571eaa2068de7

See more details on using hashes here.

File details

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

File metadata

  • Download URL: structlog_sentry_logger-0.12.2-cp37-cp37m-win_amd64.whl
  • Upload date:
  • Size: 84.5 kB
  • Tags: CPython 3.7m, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for structlog_sentry_logger-0.12.2-cp37-cp37m-win_amd64.whl
Algorithm Hash digest
SHA256 b39a9a12e87f2c503640958550e3dff8ea773ffea34c6a23e09de9cf65c35813
MD5 c4e9bac86e7a230a12f5f9a9d958f2ac
BLAKE2b-256 c7de7528bb66edd239567aec3b61fd1fb9463bc91f912f9ad3e9d136128219a3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for structlog_sentry_logger-0.12.2-cp37-cp37m-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 763ca454c857c4a23c5b2ed4cd9078da4aa264f7d3bbf1c3a7539970df0e2308
MD5 bb0da12a0a76627083f17cd03feb10d2
BLAKE2b-256 cc2e141499f3932d707644c8e1b515192c3446dd296ad4260359ef6c145f9d9d

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for structlog_sentry_logger-0.12.2-cp37-cp37m-macosx_10_16_x86_64.whl
Algorithm Hash digest
SHA256 c74f9a4d6ec7125b611ffc6287291fe5f386e9b0feee776d622b4ee820d047a5
MD5 1c5964ef9af1d2dc765d4c2c099a7cb7
BLAKE2b-256 7e31251e325ff02b921dfb00eac1816648b9d242c0f8bb190e6d3bcf4d86e76d

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