import redis.clients.jedis.Jedis;
import java.util.UUID;
public class RedisLockUtil {
private static final String LOCK_SUCCESS = "OK";
private static final Long RELEASE_SUCCESS = 1L;
private static final String LOCK_KEY_PREFIX = "redis_lock:";
/**
* 尝试获取分布式锁
* @param jedis Redis客户端
* @param lockKey 锁的key
* @param requestId 请求标识
* @param expireTime 锁的超时时间
* @return 是否获取成功
*/
public static boolean tryGetDistributedLock(Jedis jedis, String lockKey, String requestId, int expireTime) {
String result = jedis.set(lockKey, requestId, "NX", "PX", expireTime);
if (LOCK_SUCCESS.equals(result)) {
return true;
}
return false;
}
/**
* 释放分布式锁
* @param jedis Redis客户端
* @param lockKey 锁的key
* @param requestId 请求标识
* @return 是否释放成功
*/
public static boolean releaseDistributedLock(Jedis jedis, String lockKey, String requestId) {
String script = "if redis.call('get', KEYS[1]) == ARGV[1] then return redis.call('del', KEYS[1]) else return 0 end";
Object result = jedis.eval(script, Collections.singletonList(lockKey), Collections.singletonList(requestId));
if (RELEASE_SUCCESS.equals(result)) {
return true;
}
return false;
}
/**
* 获取唯一的lockKey
* @param businessKey 业务key
* @return 唯一的lockKey
*/
public static String getLockKey(String businessKey) {
return LOCK_KEY_PREFIX + businessKey;
}
/**
* 获取唯一的requestId
* @return 唯一的requestId
*/
public static String getRequestId() {
return UUID.randomUUID().toString();
}
}
这个代码实例提供了一个Redis分布式锁的工具类,其中包含了获取锁、释放锁以及生成唯一锁和请求标识符的方法。这个工具类可以被其他需要使用分布式锁的模块引用,并在业务逻辑中调用相应的方法来实现分布式锁的功能。