Sherlock是一个提供易于使用的分布式进程间锁定,能够为事先的锁定选择后端同步。当使用由多个服务或分布式服务,通常需要某种锁定机制使一次访问某些资源成为可能。分布式锁或互斥锁可以帮助您实现这一点。Sherlock提供这种方法,通过提供了一个易于使用的api方便进程间的锁定,类似于标准库的threading.lock语义。除此之外,Sherlock在管理锁的选择时候还提供了使用后端的灵活性。Sherlock同时还更加简单地扩展对于某些不支持的后端。
每个支持的后端都支持以下客户端库:
安装很简单。
pip install sherlock
注意
Sherlock将安装所有支持后端。
sherlock在api和语义层使用起来很简单,它符合标准库的threading.Lockapi。
import sherlock
from sherlock import Lock
# Configure Sherlock's locks to use Redis as the backend,
# never expire locks and retry acquiring an acquired lock after an
# interval of 0.1 second.
sherlock.configure(backend=sherlock.backends.REDIS,
expire=None,
retry_interval=0.1)
# Note: configuring sherlock to use a backend does not limit you
# another backend at the same time. You can import backend specific locks
# like RedisLock, MCLock and EtcdLock and use them just the same way you
# use a generic lock (see below). In fact, the generic Lock provided by
# sherlock is just a proxy that uses these specific locks under the hood.
# 获取一个my_lock
lock = Lock('my_lock')
# 获取锁
lock.acquire()
# 检查锁状态
lock.locked() == True
# 释放所
lock.release()
# using with statement
with Lock('my_lock'):
# do something constructive with your locked resource here
pass
# 获取非阻塞锁
lock1 = Lock('my_lock')
lock2 = Lock('my_lock')
# 成功获取 lock1
lock1.acquire()
# 尝试以非阻塞方式获取锁
lock2.acquire(False) == True # returns False
# 尝试以阻塞方式获取锁
lock2.acquire() # 阻塞直到获得超时锁定
将Sherlock配置为使用后端并不会限制您同时使用另一个后端。您可以导入后端特定的锁(如RedisLock,MCLock和EtcdLock),并以与使用普通锁相同的方式使用它们(请参见下文)。实际上,Sherlock提供的通用锁只是在后台使用这些特定锁的代理。
import sherlock
from sherlock import Lock
# Configure Sherlock's locks to use Redis as the backend
sherlock.configure(backend=sherlock.backends.REDIS)
# Acquire a lock called my_lock, this lock uses Redis
lock = Lock('my_lock')
# Now acquire locks in Memcached
from sherlock import MCLock
mclock = MCLock('my_mc_lock')
mclock.acquire()
要运行所有测试(包括集成),必须确保所有数据库都在运行。确保所 有服务都在运行:
# memcached
memcached
# redis-server
redis-server
# etcd (etcd is probably not available as package, here is the simplest way
# to run it).
wget https://github.com/coreos/etcd/releases/download/<version>/etcd-<version>-<platform>.tar.gz
tar -zxvf etcd-<version>-<platform>.gz
./etcd-<version>-<platform>/etcd
像这样运行测试:
python setup.py test
具体文档可以参考:
参考文档地址
国内地址:https://gitee.com/mirrors/sherlock
国外地址:https://github.com/vaidik/sherlock