Redission分布式锁进行unlock操作时,会提示这个异常,源码如下:
@Overridepublic void unlock() {Boolean opStatus = get(unlockInnerAsync(Thread.currentThread().getId()));if (opStatus == null) {throw new IllegalMonitorStateException("attempt to unlock lock, not locked by current thread by node id: "+ id + " thread-id: " + Thread.currentThread().getId());}******
}
为什么会这样,由于在进行lock操作时,会设置一个时间
1.当你在完成lock后,里面的业务代码执行时间大于lock时间时,进行unlock,会抛出该异常
2.多线程竞争的问题,当第一个线程完成lock,此时并未 unlock,如此,第二个线程尝试获取锁,并进行lock操作,会抛出该异常。
解决办法:
在lock或unlock前,判断下状态合法性即可,而非直接进行加锁解锁操作。