A distributed semaphore and mutex built on Redis.
Project description
A distributed semaphore and mutex built on Redis.
Installation
To install redis-semaphore, simply:
pip install redis-semaphore
Or alternatively, you can download the repository and install manually by doing:
git clone git@github.com:bluele/redis-semaphore.git cd redis-semaphore python setup.py install
Examples
from redis import Redis
from redis_semaphore import Semaphore
from threading import Thread
import urllib2
import time
semaphore = Semaphore(Redis(), count=2, namespace='example')
def task(i):
url = 'https://www.google.co.jp/'
with semaphore:
print('id: {} => {}'.format(i, urllib2.urlopen(url).code))
print('sleep...')
time.sleep(2)
def main():
threads = list()
for i in range(5):
threads.append(Thread(target=task, args=(i,)))
for th in threads:
th.start()
for th in threads:
th.join()
if __name__ == '__main__':
main()
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
Redis-Semaphore-0.2.2.tar.gz
(4.0 kB
view details)
File details
Details for the file Redis-Semaphore-0.2.2.tar.gz.
File metadata
- Download URL: Redis-Semaphore-0.2.2.tar.gz
- Upload date:
- Size: 4.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c3ce7113fda317692c27ed704e3da41444f1c004d5bd19a0aaa56adfda5bbaec
|
|
| MD5 |
c3ac847879525089ae1b7ae526757342
|
|
| BLAKE2b-256 |
30de431fbf151d1f7cf72b14d6f7ddc700310e6692aac116eda3b1e9800c9f55
|