Skip to main content

Structured logging library for Python

Project description

ctxlog

PyPI version Python versions License Documentation Status

A structured logging library for Python that provides nested, context-rich logs.

This library was inspired by the Canonical Log Lines, which emphasizes the importance of reducing the amount of noise in logs for better observability and debugging. With the addition of log chaining, ctxlog allows to create log trees that can be used to track complex operations and their context, similar to tracing mechanisms.

Features

  • Structured Logging: Structured logs with context fields with optional JSON serialization
  • Context-Rich: Extend the logs with additional context information over the course of an action
  • Log Chaining: Create nested log contexts for tracking complex operations

Documentation

Full documentation is available at ctxlog.readthedocs.io.

Installation

pip install ctxlog

Or with Poetry:

poetry add ctxlog

Quick Start

import ctxlog

# Configure the logger (optional, uses sensible defaults)
ctxlog.configure(
    level="debug",  # or ctxlog.LogLevel.INFO
    timefmt="iso",  # ISO8601 format
    utc=True,  # Use UTC for timestamps
)

# Create a logger instance
logger = ctxlog.get_logger("example")

# Simple logging
logger.debug("This is a simple debug log")
logger.info("This is a simple info log")
logger.warning("This is a simple warning log")
logger.error("This is a simple error log")
logger.critical("This is a simple critical log")

# Structured logging with context
log = logger.ctx(user_id="user123", action="login").info("User logged in")

# Exception handling
try:
    # Some code that might raise an exception
    result = 1 / 0
except Exception as e:
    log = logger.new("exception_example").ctx(dividing=1, by=0)
    log.exc(e).error("Division failed")

# Log chaining for complex operations
def process_data(data):
    log = logger.new("data_processing")

    try:
        validate_data(log.new("data_validation"), data)
    except Exception as e:
        log.exc(e).error("Data validation failed")

    log.info("Data processed successfully")

def validate_data(log, data):
    log = log.ctx(key=data["key"])

    # Validation happens

    log.info("Data validation successful")

process_data({"key": "value"})

Produces the following output

quickstart example output

Configuration

Global Configuration

import ctxlog
from ctxlog import LogLevel, ConsoleHandler, FileHandler, FileRotation

# Configure with default console handler
ctxlog.configure(
    level=LogLevel.INFO,
    timefmt="iso",  # or "%Y-%m-%d %H:%M:%S"
    utc=True,
)

# Configure with custom handlers
ctxlog.configure(
    level=LogLevel.INFO,
    handlers=[
        ConsoleHandler(
            level=LogLevel.INFO,
            serialize=False,  # Human-readable format
            color=True,
            use_stderr=False,
        ),
        FileHandler(
            level=LogLevel.DEBUG,  # More verbose in file
            serialize=True,  # JSON format
            file_path="./app.log",
            rotation=FileRotation(
                size="20MB",  # Rotate when file reaches 20MB
                keep=5,  # Keep 5 rotated files
                compression="gzip",  # Compress old files
            ),
        ),
    ],
)

Log Levels

ctxlog supports the standard log levels:

  • DEBUG (10)
  • INFO (20)
  • WARNING (30)
  • ERROR (40)
  • CRITICAL (50)

Advanced Usage

Contextual Logging

def process_payment(payment):
    log = logger.new(event="payment_process").ctx(payment_id=payment.id)
    try:
        transaction_id = charge_payment(payment)
        log.ctx(transaction_id=transaction_id).info("Payment processed")
    except Exception as e:
        log.exc(e).error("Payment failed")

Log Chaining

def process_order(order):
    log = logger.new(event="order_process").ctx(order_id=order.id)
    validate_order(log.new("validation"), order)
    log.info("Order processed")

def validate_order(log, order):
    log = log.ctx(order_id=order.id)

    # Perform validation

    log.info("Order validated")

License

MIT License

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Documentation

The documentation is built using Sphinx and hosted on ReadTheDocs. To build the documentation locally:

# Install development dependencies with documentation extras
poetry install --with docs

# Build the documentation
cd docs
poetry run make html
cd ..

The built documentation will be available in the docs/build/html directory.

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

ctxlog-1.0.0.tar.gz (15.2 kB view details)

Uploaded Source

Built Distribution

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

ctxlog-1.0.0-py3-none-any.whl (15.6 kB view details)

Uploaded Python 3

File details

Details for the file ctxlog-1.0.0.tar.gz.

File metadata

  • Download URL: ctxlog-1.0.0.tar.gz
  • Upload date:
  • Size: 15.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for ctxlog-1.0.0.tar.gz
Algorithm Hash digest
SHA256 c5b0d94d16a6c818c8d4455f60844381df40150a9417e1b2c55b4a46ce9baf89
MD5 75de201aef4a48254651db7ed4f1ef3e
BLAKE2b-256 7a1cde66ad61fece2867651d6d9c287f46455bcb292b9ab8b85d0681d1cb2c3c

See more details on using hashes here.

Provenance

The following attestation bundles were made for ctxlog-1.0.0.tar.gz:

Publisher: release.yml on czechbol/ctxlog

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ctxlog-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: ctxlog-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 15.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for ctxlog-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 03e5118f6955928e839b6658a1bd951739b1ad152473255f11fe7d3016f9ad92
MD5 2ff3a353f811dae4eed8aa8bb8b48f62
BLAKE2b-256 8a908f8d71ea81bdd8de32e237c84cfcaeb9224ddf8e725cd07c7e7b73828cac

See more details on using hashes here.

Provenance

The following attestation bundles were made for ctxlog-1.0.0-py3-none-any.whl:

Publisher: release.yml on czechbol/ctxlog

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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