Reacquiring lock for redis
Project description
Lock that prolongs itself from time to time and cancels current task if used as async context manager.
Usage
import asyncio
import logging
from redis.asyncio import Redis
from redis_extending_lock import ExtendingLock
async def main():
redis = Redis.from_url('redis://:hackme@localhost:6379/0')
lock = ExtendingLock(
redis, 'example',
timeout=2,
# optional, if not specified explicitly
# would be half of timeout
reacquiring_timeout=1,
blocking_timeout=0,
)
async with lock:
# your long-running task,
# would be cancelled if lock would be not able to extend
# for some reason
await asyncio.Future()
logging.basicConfig(level=logging.DEBUG)
asyncio.run(main())
Lock can be also used without context manager:
import asyncio
import logging
from redis.asyncio import Redis
from redis_extending_lock import ExtendingLock
async def main():
redis = Redis.from_url('redis://:hackme@localhost:6379/0')
lock = ExtendingLock(
redis, 'example', timeout=2, blocking_timeout=0,
)
await lock.acquire()
await asyncio.sleep(5)
await lock.release()
logging.basicConfig(level=logging.DEBUG)
asyncio.run(main())
How to develop
make devenv - configure the development environment
poetry shell or source .venv/bin/activate - activate virtualenv
make lint - syntax & code style check
make codestyle - reformat code
make test - test this project
make build - build this project
Versioning
This software follows Semantic Versioning.
Version is represented using MAJOR.MINOR.PATCH numbers, increment the:
MAJOR version when you make incompatible API changes
MINOR version when you add functionality in a backwards compatible manner
PATCH version when you make backwards compatible bug fixes
Additional labels for pre-release and build metadata are available as extensions to the MAJOR.MINOR.PATCH format.
In this case, the package version is assigned automatically with poem-plugins, it using on the tag in the repository as a major and minor and the counter, which takes the number of commits between tag to the head of branch.
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
Built Distribution
File details
Details for the file redis_extending_lock-1.0.2.tar.gz
.
File metadata
- Download URL: redis_extending_lock-1.0.2.tar.gz
- Upload date:
- Size: 3.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.0 CPython/3.9.16 Linux/5.15.0-1034-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 23d46e0a00b99029917973cd2f9b0e5e22da5d61dc772a009451f118de471a36 |
|
MD5 | 67c8d52f917252db46a4cc5f8d7c6593 |
|
BLAKE2b-256 | ad04082bb53366419f189062b60d38a874794301db60628bc1d5a457947c2fa9 |
File details
Details for the file redis_extending_lock-1.0.2-py3-none-any.whl
.
File metadata
- Download URL: redis_extending_lock-1.0.2-py3-none-any.whl
- Upload date:
- Size: 4.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.0 CPython/3.9.16 Linux/5.15.0-1034-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 926c4665a57933eb5b320793b012696db224f53d7d455f139482af16e5ace41f |
|
MD5 | 2e3eae3af095abe020547c95b8d499f1 |
|
BLAKE2b-256 | 96c763c5797d5eddfbb3810fc1fb20872afca8d47ddd1a555e84b7e4684b4c97 |