zoukankan      html  css  js  c++  java
  • 封装jedis自己实现锁

    package me.ele.marketing.budget.processor.lock;

    import lombok.Getter;
    import me.ele.napos.vine.misc.exception.UnexpectedStateException;
    import me.ele.napos.vine.util.lock.Lock;
    import me.ele.napos.vine.util.lock.LockFailedException;
    import me.ele.napos.vine.util.lock.LockHandle;
    import me.ele.napos.vine.util.lock.internal.LockHandleImpl;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Service;
    import redis.clients.jedis.Jedis;

    import java.awt.image.Kernel;
    import java.io.Closeable;
    import java.time.LocalDateTime;
    import java.util.concurrent.ThreadLocalRandom;

    /**

    • @author: 谢洪伟

    • 2021/7/1 5:03 下午
      */
      @Service
      public class MyRedisLock implements Lock {
      @Autowired
      private Jedis jedis;
      private ThreadLocalRandom random = ThreadLocalRandom.current();

      @Override
      public LockHandle lock(String key) throws LockFailedException {
      return null;
      }

      @Override
      public LockHandle lock(String key, int expireMills) throws LockFailedException {
      return null;
      }

      @Override
      public LockHandle lock(String key, int expireMills, int waitMills) throws LockFailedException {
      LockHandle handle = new LockHandleImpl(this, key);
      if (waitMills > 0) {
      LocalDateTime ttl = LocalDateTime.now().plusNanos(waitMills);
      do {
      String locked = jedis.set(key, handle.getToken(), "nx", "px", waitMills);
      if (locked != null) {
      return handle;
      }
      try {
      Thread.sleep(random.nextInt(10,100));
      } catch (InterruptedException e) {
      throw new UnexpectedStateException(e);
      }
      } while (LocalDateTime.now().isAfter(ttl));
      throw new RuntimeException("上锁超时");
      }else{
      String locked = jedis.set(key, handle.getToken(), "nx", "px", waitMills);
      if ( locked != null){
      return handle;
      }
      throw new RuntimeException("上锁失败");
      }
      }

      @Override
      public void unlock(LockHandle handle) {
      String token = jedis.get(handle.getKey());
      if (token.equals(handle.getToken())) {
      jedis.del(handle.getKey());
      }
      }

      public interface Handler extends Closeable {
      String getKey();

       /**
        * Lock token.
        */
       String getToken();
      
       /**
        * Release the lock.
        */
       void unlock();
      
       /**
        * The IOExceptional-off close method.
        */
       @Override
       default void close() {
           unlock();
       }
      

      }
      @Getter
      public class HandlerImpl implements Handler {
      private Lock lock;
      private String key;
      private String token;

       public HandlerImpl(Lock lock, String key) {
           this.lock = lock;
           this.key = key;
       }
      
       @Override
       public String getKey() {
           return this.key;
       }
      
       @Override
       public String getToken() {
           return null;
       }
      
       @Override
       public void unlock() {
           lock.unlock(this);
       }
      

      }

    }

  • 相关阅读:
    Vim Taglist插件的安装与配置
    static变量和static函数
    Linux线程同步读写锁 rwlock
    Linux top命令 使用详解
    Python学习资料
    记录点滴
    自定义的动态buffer
    【数据存储】【Redis】第七章:Redis缓存Zset类型的使用
    RabbitMQ:第二章:Spring整合RabbitMQ(简单模式,广播模式,路由模式,通配符模式,消息可靠性投递,防止消息丢失,TTL,死信队列,延迟队列,消息积压,消息幂等性)
    RabbitMQ:第三章:Springboot集成RabbitMQ(直连模式,工作队列模式,发布订阅模式,路由模式,通配符模式)
  • 原文地址:https://www.cnblogs.com/albertXe/p/14959918.html
Copyright © 2011-2022 走看看