Skip to main content

A simple UUID-based file lock implementation for Python.

Project description

UUID File Lock

A simple UUID-based file lock implementation for Python. This package provides a lightweight and effective way to coordinate access to shared resources using a lock file mechanism.

How It Works

  1. Lock File Check: The system checks if the lock file exists.
  2. Lock Creation: If no lock file exists, it creates one and writes a unique UUID to it.
  3. Verification: The lock waits briefly and then verifies if the UUID matches the one it wrote.
  4. Retry Logic: If the UUID mismatches or the lock file already exists, it retries after a delay.
  5. Release Mechanism: When the lock is released, the lock file is deleted if it contains the same UUID.

This mechanism ensures that only one process can hold the lock at any time, making it ideal for coordinating file or resource access across multiple processes.

Installation

Install the package via pip:

pip install uuid-filelock

Usage

You can use the UUIDFileLock class to acquire and release locks in your Python code. The class also supports usage within a with clause for convenience.

Example: Using the Lock Explicitly

import time
from uuid_filelock import UUIDFileLock

lock_file_path = "/tmp/mylockfile.lock"
lock = UUIDFileLock(lock_file_path)

try:
    print("Trying to acquire lock...")
    lock.acquire()
    print("Lock acquired!")

    # Perform critical section tasks here
    # Simulating work
    time.sleep(5)

finally:
    lock.release()
    print("Lock released.")

Example: Using the Lock in a with Clause

import time
from uuid_filelock import UUIDFileLock

lock_file_path = "/tmp/mylockfile.lock"

with UUIDFileLock(lock_file_path) as lock:
    print("Lock acquired!")
    # Perform critical section tasks
    time.sleep(5)  # Simulate work
    print("Work done!")

# The lock is automatically released when the block exits.
print("Lock released.")

Parameters

  • lock_file (str): The path to the lock file.
  • prefix (str, default=""): A custom prefix for the UUID to help debugging.
  • verification_delay (float, default=1.0): Time to wait before verifying that the lock was acquired.
  • retry_interval (float, default=0.1): Time to wait before retrying if the lock cannot be acquired.
  • timeout_interval (float, default=-1): Timeout for acquiring lock. Set to negative value for no timeout.

License

This package is licensed under the MIT License.

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

uuid_filelock-1.3.tar.gz (4.6 kB view details)

Uploaded Source

Built Distribution

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

uuid_filelock-1.3-py3-none-any.whl (3.4 kB view details)

Uploaded Python 3

File details

Details for the file uuid_filelock-1.3.tar.gz.

File metadata

  • Download URL: uuid_filelock-1.3.tar.gz
  • Upload date:
  • Size: 4.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.0.1 CPython/3.12.8

File hashes

Hashes for uuid_filelock-1.3.tar.gz
Algorithm Hash digest
SHA256 352164fae1ae2922a4ed1ab79c4880ad11fa37a1169aecfee10576a02f03cbfa
MD5 f2e482989ae4952ec254c34933e5782f
BLAKE2b-256 177fe1e95c34bb1f6f05761049464aa0e6c88b13992cab030375155fbe757c8d

See more details on using hashes here.

Provenance

The following attestation bundles were made for uuid_filelock-1.3.tar.gz:

Publisher: python-publish.yml on z3rone-org/uuid_filelock

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

File details

Details for the file uuid_filelock-1.3-py3-none-any.whl.

File metadata

  • Download URL: uuid_filelock-1.3-py3-none-any.whl
  • Upload date:
  • Size: 3.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.0.1 CPython/3.12.8

File hashes

Hashes for uuid_filelock-1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 b7c68d36de3c18393ae78d2d59f76e42e4b40c8c995ffedc685a9b2c73aa0fc4
MD5 ec7892e89a005ba776cb99379b059f5d
BLAKE2b-256 55cc386d42dbd80f85c515fb589b2cae5f19beb33a3da7a6499edff63bc622a8

See more details on using hashes here.

Provenance

The following attestation bundles were made for uuid_filelock-1.3-py3-none-any.whl:

Publisher: python-publish.yml on z3rone-org/uuid_filelock

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