PIDFile context manager.
Project description
Python context manager for managing pid files. Example usage:
import pidfile
import time
print('Starting process')
try:
with pidfile.PIDFile("/var/run/example.pid"):
print('Process started')
time.sleep(30)
except pidfile.AlreadyRunningError:
print('Already running.')
print('Exiting')
The context manager will take care of verifying the existence of a pid file, check its pid to see if it’s alive, check the command line (which should be <something>/<python name>), and if all the conditions are met, rise a pidfile.AlreadyRunningError exception.
PIDFile() defaults to pidfile for the file name, but it’s possible to specify another, e.g. PIDFile(‘foobar.pid’).
Under the hood
The algorithm of the library is very simple, at startup, a file is created, and after checking that another instance of the program is not running, the current process ID is written to it.
The check works as follows:
If the file does not exist, then the check is passed.
An identifier is written in the file, it is read and checked that a process running with such an identifier exists, and has the same command line.
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 Distribution
Built Distribution
Hashes for python_pidfile-3.1.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | c5f408504303ae0e7f89f22e2818fa67f5797279b474d263f483f4887c093dd7 |
|
MD5 | dd65f5764a0e6c82bd32f972414aa8dd |
|
BLAKE2b-256 | 9bfc706f96514a30365462baa0173deeb6ebd568dacc0767e76c18feafc97fb7 |