|
|
@ -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++;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|