Logger for multiprocessing applications
Project description
multiprocessing-logging
When using the multiprocessing
module, logging becomes less useful since
sub-processes should log to individual files/streams or there's the risk of
records becoming garbled.
This simple module implements a Handler
that when set on the root
Logger
will handle tunneling the records to the main process so that
they are handled correctly.
It's currently tested in Linux and Python 2.7 & 3.5+.
Pypy3 hangs on the tests so I don't recommend using it.
Pypy appears to be working, recently.
It was tested by users and reported to work on Windows with Python 3.5 and 3.6.
Origin
This library was taken verbatim from a StackOverflow post and extracted into a module so that I wouldn't have to copy the code in every project.
Later, several improvements have been contributed.
Usage
Before you start logging but after you configure the logging framework (maybe with logging.basicConfig(...)
), do the following:
import multiprocessing_logging
multiprocessing_logging.install_mp_handler()
and that's it.
With multiprocessing.Pool
When using a Pool, make sure install_mp_handler
is called before the Pool is instantiated, for example:
import logging
from multiprocessing import Pool
from multiprocessing_logging import install_mp_handler
loggig.basicConfig(...)
install_mp_handler()
pool = Pool(...)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
File details
Details for the file multiprocessing_logging-0.3.0-py2.py3-none-any.whl
.
File metadata
- Download URL: multiprocessing_logging-0.3.0-py2.py3-none-any.whl
- Upload date:
- Size: 7.9 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.7.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 76790aebe751a40c8bb63175e204db73b7a78b3d4e0b73a96b6d02a11b2630f5 |
|
MD5 | 08cd33e412b28f946fba4e0c7bf5c9c7 |
|
BLAKE2b-256 | 7630251cdbbb71b9abe4164dfe70a1341cde21098918c50eecd882c0d32f65ad |