Skip to main content

Narration is a logging library starting a server receiving log records from other process.

Project description

https://img.shields.io/pypi/v/narration.svg https://img.shields.io/pypi/pyversions/narration.svg https://img.shields.io/pypi/status/narration.svg https://img.shields.io/pypi/l/narration.svg

narration

Logging is easy, but setup is messy and boring in multi processes contexts, due to the various way python can spawn processes (fork, spawn, forkserver) via explicit or implicit spawning context.

Narration handles the following logging setup boiler plate:

  • main process’s logger writes log record emitted by the process itself or its child processes

  • child process’s logger’s handler forward log records to the main process only

Installation

Install python virtual envs needed by tox/IDE

bash make.sh --setup-python-dev-envs
bash make.sh --install-dependencies
bash make.sh --install-tests-dependencies

Usage

  • Create your loggers as you like (eg: logging.basicConfig(…))

  • On the master process, setup the logger to act as server:

import narration
import multiprocessing
import logging

ctx = mutiprocessing.get_context()
m = ctx.Manager()

logger=logging.getLogger()
client_handler_settings = narration.setup_server_handlers(logger=logger, ctx=ctx, ctx_manager=m)
logger.debug("Main process ready")

pool = multiprocessing.pool.Pool(10, child_process_worker_function, [client_handler_settings] , 2, ctx)
  • On the child process, setup the logger to act as ‘emitting’ client:

import narration
import multiprocessing
import logging

# Child process must receive the 'client_handler_settings' payload when starting the process

# Re-create a logger, replacing handlers/formatting (if any) with handler to forrward records to the master process
logger=logging.getLogger()
narration.setup_client_handlers(logger=logger, handler_name_to_client_handler_settings=client_handler_settings)
logger.debug("Child process ready")
  • Child process log records will be sent to the master process’s logger’s original handlers for procesing.

Main process ready
Child process ready

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

narration-0.2.19.tar.gz (29.8 kB view details)

Uploaded Source

Built Distribution

narration-0.2.19-py2.py3-none-any.whl (44.5 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file narration-0.2.19.tar.gz.

File metadata

  • Download URL: narration-0.2.19.tar.gz
  • Upload date:
  • Size: 29.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.9.19

File hashes

Hashes for narration-0.2.19.tar.gz
Algorithm Hash digest
SHA256 23a06969583d2e1703b14d09a40a9f73fe784ab7a177b63d1408a2f9aee19477
MD5 fb1ed99c58a87255f422d3c747e25897
BLAKE2b-256 83e3ddd16139dac7f89439f0cc20d0293ace158d30268b20717ff3349540e960

See more details on using hashes here.

File details

Details for the file narration-0.2.19-py2.py3-none-any.whl.

File metadata

  • Download URL: narration-0.2.19-py2.py3-none-any.whl
  • Upload date:
  • Size: 44.5 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.9.19

File hashes

Hashes for narration-0.2.19-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 6fd023ffea12b0326b9a6c81581917aa1999b92f4929bde054a83dba3621ec91
MD5 da7fa05c9ae2c64c8f35747a84348a83
BLAKE2b-256 cd05ae408cca90d6ab696eaecf7d516314d820a6c88f9d6853f3bf44b5be7528

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