利用setnx函数实现分布式锁的基本思路是:
-
使用setnx命令尝试在redis中设置一个指定的key,如果该key不存在则返回1,表示成功获取锁;如果该key已经存在则返回0,表示获取锁失败。
-
在获取锁成功后,设置一个过期时间,确保锁在一定时间内自动释放,避免锁被长时间占用造成死锁。
-
在释放锁时,使用del命令删除该key,确保锁释放成功。
以下是一个简单的示例代码来实现分布式锁:
import redis import time # 连接redis redis_client = redis.Redis(host='localhost', port=6379, db=0) # 获取分布式锁 def acquire_lock(lock_key, expire_time=10): lock = redis_client.setnx(lock_key, time.time() + expire_time) if lock: return True current_time = time.time() # 判断锁是否过期 if current_time > float(redis_client.get(lock_key) or 0): # 如果锁已经过期,则重新设置锁 new_expire_time = current_time + expire_time old_expire_time = float(redis_client.getset(lock_key, new_expire_time) or 0) if old_expire_time == current_time: return True return False # 释放分布式锁 def release_lock(lock_key): current_time = time.time() if current_time < float(redis_client.get(lock_key) or 0): redis_client.delete(lock_key) return True return False # 测试分布式锁 lock_key = "distributed_lock" if acquire_lock(lock_key): try: # 业务逻辑处理 print("获取锁成功,执行业务逻辑") finally: release_lock(lock_key) else: print("获取锁失败")
在上面的示例中,首先通过acquire_lock函数尝试获取分布式锁,成功获取锁后执行业务逻辑,最后通过release_lock函数释放锁。通过这种方式可以确保在分布式环境下对资源的互斥访问。