java.lang.IllegalStateException: Lock was released in the store due to expiration.

报错内容:

java.lang.IllegalStateException: Lock was released in the store due to expiration. The integrity of data protected by this lock may have been compromised.       
at org.springframework.integration.redis.util.RedisLockRegistry$RedisLock.unlock(RedisLockRegistry.java:310) 

处理方式:

1.

public RedisLockRegistry(RedisConnectionFactory connectionFactory, String registryKey) {
	//private static final long DEFAULT_EXPIRE_AFTER = 60000L; 1分钟
	this(connectionFactory, registryKey, DEFAULT_EXPIRE_AFTER);
}

看下用该类创建的redis锁的定义,是不是用了默认的超时时间,一分钟可能锁就释放了,导致上述问题.

2.

finally {
   	try {
        lock.unlock();
    } catch (Exception e) {
        //noinspection ThrowFromFinallyBlock
        throw new DataVerifyException(Error.builder().responseCode(ResponseCode.DATA_VERIFY_EXCEPTION).message("该操作频繁,请稍后再试").build());
    }
}

释放锁的操作用try包一下(这个是可选项,具体原因看下面扩展)

扩展延伸:

详细解释

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值