在Java中实现Redis分布式锁可以使用Redis的SETNX命令来实现。以下是一个简单的示例代码:
import redis.clients.jedis.Jedis;
public class RedisDistributedLock {
private final Jedis jedis;
private final String lockKey;
private final long expireTime;
public RedisDistributedLock(Jedis jedis, String lockKey, long expireTime) {
this.jedis = jedis;
this.lockKey = lockKey;
this.expireTime = expireTime;
}
public boolean tryLock() {
String result = jedis.set(lockKey, "", "NX", "EX", expireTime);
return "OK".equals(result);
}
public void unlock() {
jedis.del(lockKey);
}
}
上述代码中,RedisDistributedLock
类在构造函数中接收一个Jedis实例、锁的键名和过期时间。tryLock
方法会使用Redis的SETNX命令来尝试获取锁,如果返回结果为"OK",表示获取锁成功;否则表示获取锁失败。unlock
方法会释放锁,即删除对应的键。
使用示例:
import redis.clients.jedis.Jedis;
public class Main {
public static void main(String[] args) {
Jedis jedis = new Jedis("localhost", 6379);
RedisDistributedLock lock = new RedisDistributedLock(jedis, "mylock", 10);
if (lock.tryLock()) {
try {
// 获取到锁之后的业务逻辑
System.out.println("获取到锁");
} finally {
lock.unlock();
}
} else {
// 未获取到锁的处理逻辑
System.out.println("未获取到锁");
}
jedis.close();
}
}
在上述示例中,首先创建一个Jedis实例,然后创建一个RedisDistributedLock
对象,指定锁的键名为"mylock",过期时间为10秒。然后调用tryLock
方法尝试获取锁,如果获取成功,则执行获取到锁后的业务逻辑,最后释放锁。如果获取锁失败,则执行未获取到锁的处理逻辑。
需要注意的是,当锁的过期时间设置得较长时,可能会出现死锁的情况。为了避免死锁,可以在业务逻辑中增加一个超时机制,当超过一定时间仍未完成业务逻辑时,可以主动释放锁。