MCPcopy Index your code
hub / github.com/hynek/structlog

github.com/hynek/structlog @26.1.0 sqlite

repository ↗ · DeepWiki ↗ · release 26.1.0 ↗
1,098 symbols 3,419 edges 46 files 808 documented · 74% 7 cross-repo links
README

structlog: Structured Logging for Python

structlog: Structured Logging for Python

Documentation License: MIT / Apache 2.0 No AI slop inside. DOI Supported Python versions of the current PyPI release. Downloads per month

Simple. Powerful. Fast. Pick three.

structlog is the production-ready logging solution for Python:

  • Simple: Everything is about functions that take and return dictionaries – all hidden behind familiar APIs.
  • Powerful: Functions and dictionaries aren’t just simple but also powerful. structlog leaves you in control.
  • Fast: structlog is not hamstrung by designs of yore. Its flexibility comes not at the price of performance.

Thanks to its flexible design, you choose whether you want structlog to take care of the output of your log entries or whether you prefer to forward them to an existing logging system like the standard library's logging module.

The output format is just as flexible and structlog comes with support for JSON, logfmt, as well as pretty console output out-of-the-box:

Screenshot of colorful structlog output with ConsoleRenderer

Sponsors

structlog would not be possible without our amazing sponsors. Especially those generously supporting us at the The Organization tier and higher:

Please consider joining them to help make structlog’s maintenance more sustainable!

Introduction

structlog has been successfully used in production at every scale since 2013, while embracing cutting-edge technologies like asyncio, context variables, or type hints as they emerged. Its paradigms proved influential enough to help design structured logging packages across ecosystems.

A short explanation on why structured logging is good for you, and why structlog is the right tool for the job can be found in the Why chapter of our documentation.

Once you feel inspired to try it out, check out our friendly Getting Started tutorial.

For a fully-fledged zero-to-hero tutorial, check out A Comprehensive Guide to Python Logging with structlog.

If you prefer videos over reading, check out Markus Holtermann's talk Logging Rethought 2: The Actions of Frank Taylor Jr.:

Credits

structlog is written and maintained by Hynek Schlawack. The idea of bound loggers is inspired by previous work by Jean-Paul Calderone and David Reid.

The development is kindly supported by my employer Variomedia AG, structlog’s Tidelift subscribers, and all my amazing GitHub Sponsors.

The logs-loving beaver logo has been contributed by Lynn Root.

Project Links

structlog for Enterprise

Available as part of the Tidelift Subscription.

The maintainers of structlog and thousands of other packages are working with Tidelift to deliver commercial support and maintenance for the open source packages you use to build your applications. Save time, reduce risk, and improve code health, while paying the maintainers of the exact packages you use.

Core symbols most depended-on inside this repo

bind
called by 49
src/structlog/stdlib.py
stub
called by 29
tests/helpers.py
bind_contextvars
called by 21
src/structlog/contextvars.py
configure
called by 19
src/structlog/_config.py
exception
called by 18
src/structlog/stdlib.py
get_contextvars
called by 17
src/structlog/contextvars.py
get_threadlocal
called by 16
src/structlog/threadlocal.py
get_default_level_styles
called by 16
src/structlog/dev.py

Shape

Method 763
Function 183
Class 151
Route 1

Languages

Python100%

Modules by API surface

tests/test_stdlib.py118 symbols
src/structlog/stdlib.py84 symbols
tests/test_dev.py80 symbols
src/structlog/processors.py63 symbols
tests/processors/test_renderers.py57 symbols
tests/test_tracebacks.py51 symbols
tests/test_config.py50 symbols
tests/processors/test_processors.py49 symbols
tests/test_threadlocal.py45 symbols
tests/test_output.py42 symbols
tests/test_twisted.py40 symbols
tests/test_native.py39 symbols

For agents

$ claude mcp add structlog \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact