public class DistributedLockUtil {
private static Logger logger = LoggerFactory.getLogger(DistributedLockUtil.class);
JdRedisUtils jdCacheUtils;
//锁名称
private String DistributedLock = null;
//锁的值
private Long lockValue = null;
//锁设置的超时时间
private Long locktimeout = null;
//锁设置的起始时间
private Date setLockTime = null;
public DistributedLockUtil(String lock,JdRedisUtils jdCacheUtil)
{
DistributedLock = "yn_" + lock;
jdCacheUtils = jdCacheUtil;
}
/*
* @Title: getDistributedLock
* @Description: 获取分布式锁
* @param lock; timeoutSec:是秒级别的超时时间。请根据实际情况设置锁的超时时间,不能随意设置。
* 另外注意:使用完后,要及时释放锁。
* @return true表示获取锁成功;false表示获取锁失败
*/
public boolean getDistributedLock(Long timeoutSec)
{
try {
//设置超时时间点(从当前系统时间算起)
Date now = new Date();
Long lockTimeout = now.getTime() + timeoutSec * 1000;
//设置锁相关信息
setLockTime = now;
locktimeout = timeoutSec;
lockValue = lockTimeout;
//获取锁
boolean isGetLock = jdCacheUtils.setNX(DistributedLock, lockTimeout.toString());
//获取锁成功
if(isGetLock == true)
{
try {
//设置锁的有效期
jdCacheUtils.expire(DistributedLock, timeoutSec, TimeUnit.SECONDS);
logger.error("正常加锁成功。lock:" +</
Redis分布式锁
最新推荐文章于 2023-05-24 09:18:36 发布