赞
踩
目录
attempt to unlock lock, not locked by current thread by node id: d04c7c1e-6f56-4c59-9983-bc390dec9a49 thread-id: 506
设置等待时间为10秒,过期时间10秒,出现多次执行
rLock.tryLock(10, 10, TimeUnit.SECONDS);
在thread-1还没有结束的时候,也就是在thread-1在获得锁但是还没有释放锁的时候, `thread-2由于被别的线程中断停止了等待从lock.tryLock的阻塞状态中返回继续执行接下来的逻辑,并且由于尝试去释放一个属于线程thread-1的锁而抛出了一个运行时异常导致该线程thread-2结束了, 然而thread-2完成了一系列操作后,线程thread-1才释放了自己的锁. 所以thread-2并没有获得锁,却执行了需要同步的内容,还尝试去释放锁。那解决方式我们就知道了,当前线程加的锁由当前线程去解锁,也就是说当我们使用lock.unlock的时候加上线程的判断即可。
这个时候如果任务3秒就执行完成了,但是其他线程又将在等待的10秒内获取到锁继续执行
- RLock lock = redissonClient.getLock(key);
- if(lock.isLocked()){ // 是否还是锁定状态
- if(lock.isHeldByCurrentThread()){ // 时候是当前执行线程的锁
- lock.unlock(); // 释放锁
- }
- }
将等待时间设置为0
rLock.tryLock(0, 10, TimeUnit.SECONDS);
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。