修复redis 分布式锁可能解除失败问题

v1.4.1
Parker 4 years ago
parent 72b290bf33
commit 014d97a7f8

@ -55,7 +55,7 @@ public class RedisLock {
private String identifier; private String identifier;
/** 线程锁 */ /** 线程锁 */
private AtomicInteger atomicInteger; private final AtomicInteger atomicInteger;
/** /**
* *

@ -15,6 +15,7 @@
*/ */
package org.opsli.plugins.redis.lock; package org.opsli.plugins.redis.lock;
import cn.hutool.core.thread.ThreadUtil;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.opsli.plugins.redis.RedisLockPlugins; import org.opsli.plugins.redis.RedisLockPlugins;
import org.opsli.plugins.redis.RedisPlugin; import org.opsli.plugins.redis.RedisPlugin;
@ -82,6 +83,9 @@ public class RedisLockImpl implements RedisLockPlugins {
*/ */
@Override @Override
public boolean unLock(RedisLock redisLock) { public boolean unLock(RedisLock redisLock) {
if(redisLock == null){
return false;
}
try { try {
List<String> keys = Collections.singletonList(LOCK_NAME_PREFIX + redisLock.getLockName()); List<String> keys = Collections.singletonList(LOCK_NAME_PREFIX + redisLock.getLockName());
Long ret = (Long) redisPlugin.callScript(RedisScriptsEnum.REDIS_UN_LOCK, keys, Long ret = (Long) redisPlugin.callScript(RedisScriptsEnum.REDIS_UN_LOCK, keys,
@ -120,11 +124,7 @@ public class RedisLockImpl implements RedisLockPlugins {
if (1 == ret){ if (1 == ret){
acquired = true; acquired = true;
} else { } else {
try { ThreadUtil.sleep(10);
Thread.sleep(10);
} catch (InterruptedException ignored) {
log.error(ignored.getMessage(),ignored);
}
} }
} }
redisLock.setIdentifier(identifier); redisLock.setIdentifier(identifier);
@ -141,27 +141,25 @@ public class RedisLockImpl implements RedisLockPlugins {
* @return boolean * @return boolean
*/ */
private void lockDog(RedisLock redisLock) { private void lockDog(RedisLock redisLock) {
if(redisLock == null){
return;
}
Thread t = new Thread(()->{ Thread t = new Thread(()->{
try { try {
// 倒计时前续命 // 倒计时前续命
long countDownTime = 3000L; long countDownTime = 3000L;
// 锁释放时间 // 锁释放时间
long lockTimeOutEnd = System.currentTimeMillis() + redisLock.getLockTimeOut(); long lockTimeOutEnd = System.currentTimeMillis() + redisLock.getLockTimeOut();
boolean dogFlag = true;
// 看门狗检测 当前线程是否还存活 // 看门狗检测 当前线程是否还存活
while (dogFlag) { while (true) {
int lock = redisLock.threadGetLock(); int lock = redisLock.threadGetLock();
if(lock <= 0){ if(lock <= 0){
dogFlag = false;
// 再一次确定 解锁 防止线程差 最后加锁 // 再一次确定 解锁 防止线程差 最后加锁
this.unLock(redisLock); this.unLock(redisLock);
break; break;
} }
try {
Thread.sleep(10); ThreadUtil.sleep(10);
} catch (InterruptedException ignored) {
log.error(ignored.getMessage(),ignored);
}
// 如果 距离倒计时 前 2000 毫秒还没有动作 则执行续命 // 如果 距离倒计时 前 2000 毫秒还没有动作 则执行续命
if((System.currentTimeMillis()+countDownTime) >= lockTimeOutEnd){ if((System.currentTimeMillis()+countDownTime) >= lockTimeOutEnd){
@ -189,4 +187,13 @@ public class RedisLockImpl implements RedisLockPlugins {
private String getInfo(String name,RedisLock redisLock){ private String getInfo(String name,RedisLock redisLock){
return name + " 锁名称: "+redisLock.getLockName()+" 锁凭证: "+redisLock.getIdentifier(); return name + " 锁名称: "+redisLock.getLockName()+" 锁凭证: "+redisLock.getIdentifier();
} }
public static void main(String[] args) {
int count = 0;
while (count <= 10) {
System.out.println(count);
count++;
}
}
} }

@ -35,8 +35,8 @@ public enum RedisMsg implements BaseMsg {
; ;
private int code; private final int code;
private String message; private final String message;
RedisMsg(int code, String message){ RedisMsg(int code, String message){
this.code = code; this.code = code;

@ -32,7 +32,7 @@ public enum RedisScriptsEnum {
; ;
/** 脚本路径 */ /** 脚本路径 */
private String path; private final String path;
RedisScriptsEnum(String path){ RedisScriptsEnum(String path){
this.path = path; this.path = path;

Loading…
Cancel
Save