attempt to unlock lock, not locked by current thread by node id异常

Redission分布式锁进行unlock操作时,会提示这个异常,源码如下:

    @Override
    public 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前,判断下状态合法性即可,而非直接进行加锁解锁操作。

你可能感兴趣的:(java,开发语言)