Package org.redisson

Class RedissonFasterMultiLock

All Implemented Interfaces:
Lock, RExpirable, RExpirableAsync, RLock, RLockAsync, RObject, RObjectAsync

public class RedissonFasterMultiLock extends RedissonBaseLock
RedissonFasterMultiLock.
All lock, unlock, lockAsync unlockAsync methods only success when all values locked succeed.
Example:
there is a class, id is 100, and three students in class, Jack(id:001),Mary(id:002)
  • current thread id : 1
  • ServiceManager id: 71b96ce8-2746......
  • current time stamp: 1727422868000
when redissonBatchLock.lock("class_100",Arrays.asList("Jack_001","Mary_002")
It will be saved In redis like this:
 -----------------------------------------------------------------------
 | redis type: hash                                                    |
 | redis Key: class_100                                                |
 -----------------------------------------------------------------------
 | field                                           | value             |
 -----------------------------------------------------------------------
 | Jack_001                                        | 71b96ce8-2746:1   |
 | Mary_002                                        | 71b96ce8-2746:1   |
 | Jack_001:71b96ce8-2746:1:expire_time            | 1,727,422,898,000 |
 | Jack_001:71b96ce8-2746:1:lock_count             | 1                 |
 | Mary_002:71b96ce8-2746:1:expire_time            | 1,727,422,898,000 |
 | Mary_002:71b96ce8-2746:1:lock_count             | 1                 |
 -----------------------------------------------------------------------
 
Attention: the value of group should be `smallest`, in our example above , group should be 'class_100' not just 'class'
Of course the values `Jack_001`,`Mary_002` will be encoded and hashed.
Author:
lyrric
  • Field Details

    • internalLockLeaseTime

      protected long internalLockLeaseTime
  • Constructor Details

  • Method Details

    • getName

      public String getName()
      Description copied from interface: RObject
      Returns name of object
      Specified by:
      getName in interface RLock
      Specified by:
      getName in interface RObject
      Overrides:
      getName in class RedissonObject
      Returns:
      name - name of object
    • lockInterruptibly

      public void lockInterruptibly(long leaseTime, TimeUnit unit) throws InterruptedException
      Description copied from interface: RLock
      Acquires the lock with defined leaseTime. Waits if necessary until lock became available. Lock will be released automatically after defined leaseTime interval.
      Parameters:
      leaseTime - the maximum time to hold the lock after it's acquisition, if it hasn't already been released by invoking unlock. If leaseTime is -1, hold the lock until explicitly unlocked.
      unit - the time unit
      Throws:
      InterruptedException - - if the thread is interrupted
    • tryLock

      public boolean tryLock(long waitTime, long leaseTime, TimeUnit unit) throws InterruptedException
      Description copied from interface: RLock
      Tries to acquire the lock with defined leaseTime. Waits up to defined waitTime if necessary until the lock became available. Lock will be released automatically after defined leaseTime interval.
      Parameters:
      waitTime - the maximum time to acquire the lock
      leaseTime - lease time
      unit - time unit
      Returns:
      true if lock is successfully acquired, otherwise false if lock is already set.
      Throws:
      InterruptedException - - if the thread is interrupted
    • lock

      public void lock(long leaseTime, TimeUnit unit)
      Description copied from interface: RLock
      Acquires the lock with defined leaseTime. Waits if necessary until lock became available. Lock will be released automatically after defined leaseTime interval.
      Parameters:
      leaseTime - the maximum time to hold the lock after it's acquisition, if it hasn't already been released by invoking unlock. If leaseTime is -1, hold the lock until explicitly unlocked.
      unit - the time unit
    • unsubscribe

      protected void unsubscribe(RedissonLockEntry entry)
    • subscribe

      protected CompletableFuture<RedissonLockEntry> subscribe()
    • renewExpirationAsync

      protected CompletionStage<Boolean> renewExpirationAsync(long threadId)
      Overrides:
      renewExpirationAsync in class RedissonBaseLock
    • forceUnlock

      public boolean forceUnlock()
      Description copied from interface: RLock
      Unlocks the lock independently of its state
      Specified by:
      forceUnlock in interface RLock
      Overrides:
      forceUnlock in class RedissonBaseLock
      Returns:
      true if lock existed and now unlocked otherwise false
    • isLocked

      public boolean isLocked()
      Description copied from interface: RLock
      Checks if the lock locked by any thread
      Specified by:
      isLocked in interface RLock
      Overrides:
      isLocked in class RedissonBaseLock
      Returns:
      true if locked otherwise false
    • isHeldByThread

      public boolean isHeldByThread(long threadId)
      Description copied from interface: RLock
      Checks if the lock is held by thread with defined threadId
      Specified by:
      isHeldByThread in interface RLock
      Overrides:
      isHeldByThread in class RedissonBaseLock
      Parameters:
      threadId - Thread ID of locking thread
      Returns:
      true if held by thread with given id otherwise false
    • isHeldByCurrentThread

      public boolean isHeldByCurrentThread()
      Description copied from interface: RLock
      Checks if this lock is held by the current thread
      Specified by:
      isHeldByCurrentThread in interface RLock
      Overrides:
      isHeldByCurrentThread in class RedissonBaseLock
      Returns:
      true if held by current thread otherwise false
    • getHoldCount

      public int getHoldCount()
      Description copied from interface: RLock
      Number of holds on this lock by the current thread
      Specified by:
      getHoldCount in interface RLock
      Overrides:
      getHoldCount in class RedissonBaseLock
      Returns:
      holds or 0 if this lock is not held by current thread
    • remainTimeToLive

      public long remainTimeToLive()
      Description copied from interface: RExpirable
      Returns remaining time of the object in milliseconds.
      Specified by:
      remainTimeToLive in interface RExpirable
      Specified by:
      remainTimeToLive in interface RLock
      Returns:
      time in milliseconds -2 if the key does not exist. -1 if the key exists but has no associated expire.
    • lock

      public void lock()
    • unlockInnerAsync

      protected RFuture<Boolean> unlockInnerAsync(long threadId, String requestId, int timeout)
      Specified by:
      unlockInnerAsync in class RedissonBaseLock
    • lockInterruptibly

      public void lockInterruptibly() throws InterruptedException
      Throws:
      InterruptedException
    • tryLock

      public boolean tryLock()
    • tryLock

      public boolean tryLock(long waitTime, TimeUnit unit) throws InterruptedException
      Throws:
      InterruptedException
    • forceUnlockAsync

      public RFuture<Boolean> forceUnlockAsync()
      Description copied from interface: RLockAsync
      Unlocks the lock independently of its state
      Returns:
      true if lock existed and now unlocked otherwise false
    • unlockAsync

      public RFuture<Void> unlockAsync()
      Description copied from interface: RLockAsync
      Unlocks the lock
      Specified by:
      unlockAsync in interface RLockAsync
      Overrides:
      unlockAsync in class RedissonBaseLock
      Returns:
      void
    • unlockAsync

      public RFuture<Void> unlockAsync(long threadId)
      Description copied from interface: RLockAsync
      Unlocks the lock. Throws IllegalMonitorStateException if lock isn't locked by thread with specified threadId.
      Specified by:
      unlockAsync in interface RLockAsync
      Overrides:
      unlockAsync in class RedissonBaseLock
      Parameters:
      threadId - id of thread
      Returns:
      void
    • lockAsync

      public RFuture<Void> lockAsync(long leaseTime, TimeUnit unit, long currentThreadId)
      Description copied from interface: RLockAsync
      Acquires the lock with defined leaseTime and threadId. Waits if necessary until lock became available. Lock will be released automatically after defined leaseTime interval.
      Parameters:
      leaseTime - the maximum time to hold the lock after it's acquisition, if it hasn't already been released by invoking unlock. If leaseTime is -1, hold the lock until explicitly unlocked.
      unit - the time unit
      currentThreadId - id of thread
      Returns:
      void
    • tryLockAsync

      public RFuture<Boolean> tryLockAsync()
      Description copied from interface: RLockAsync
      Tries to acquire the lock.
      Specified by:
      tryLockAsync in interface RLockAsync
      Overrides:
      tryLockAsync in class RedissonBaseLock
      Returns:
      true if lock acquired otherwise false
    • tryLockAsync

      public RFuture<Boolean> tryLockAsync(long threadId)
      Description copied from interface: RLockAsync
      Tries to acquire the lock by thread with specified threadId.
      Parameters:
      threadId - id of thread
      Returns:
      true if lock acquired otherwise false
    • tryLockAsync

      public RFuture<Boolean> tryLockAsync(long waitTime, TimeUnit unit)
      Description copied from interface: RLockAsync
      Tries to acquire the lock. Waits up to defined waitTime if necessary until the lock became available.
      Specified by:
      tryLockAsync in interface RLockAsync
      Overrides:
      tryLockAsync in class RedissonBaseLock
      Parameters:
      waitTime - the maximum time to acquire the lock
      unit - time unit
      Returns:
      true if lock is successfully acquired, otherwise false if lock is already set.
    • tryLockAsync

      public RFuture<Boolean> tryLockAsync(long waitTime, long leaseTime, TimeUnit unit)
      Description copied from interface: RLockAsync
      Tries to acquire the lock with defined leaseTime. Waits up to defined waitTime if necessary until the lock became available. Lock will be released automatically after defined leaseTime interval.
      Specified by:
      tryLockAsync in interface RLockAsync
      Overrides:
      tryLockAsync in class RedissonBaseLock
      Parameters:
      waitTime - the maximum time to acquire the lock
      leaseTime - lease time
      unit - time unit
      Returns:
      true if lock is successfully acquired, otherwise false if lock is already set.
    • tryLockAsync

      public RFuture<Boolean> tryLockAsync(long waitTime, long leaseTime, TimeUnit unit, long currentThreadId)
      Description copied from interface: RLockAsync
      Tries to acquire the lock by thread with specified threadId and leaseTime. Waits up to defined waitTime if necessary until the lock became available. Lock will be released automatically after defined leaseTime interval.
      Parameters:
      waitTime - time interval to acquire lock
      leaseTime - time interval after which lock will be released automatically
      unit - the time unit of the waitTime and leaseTime arguments
      currentThreadId - id of thread
      Returns:
      true if lock acquired otherwise false
    • isHeldByThreadAsync

      public RFuture<Boolean> isHeldByThreadAsync(long threadId)
      Description copied from interface: RLockAsync
      Checks if the lock is held by thread with defined threadId
      Specified by:
      isHeldByThreadAsync in interface RLockAsync
      Overrides:
      isHeldByThreadAsync in class RedissonBaseLock
      Parameters:
      threadId - Thread ID of locking thread
      Returns:
      true if held by thread with given id otherwise false
    • getHoldCountAsync

      public RFuture<Integer> getHoldCountAsync()
      Description copied from interface: RLockAsync
      Number of holds on this lock by the current thread
      Specified by:
      getHoldCountAsync in interface RLockAsync
      Overrides:
      getHoldCountAsync in class RedissonBaseLock
      Returns:
      holds or 0 if this lock is not held by current thread
    • isLockedAsync

      public RFuture<Boolean> isLockedAsync()
      Description copied from interface: RLockAsync
      Checks if the lock locked by any thread
      Specified by:
      isLockedAsync in interface RLockAsync
      Overrides:
      isLockedAsync in class RedissonBaseLock
      Returns:
      any one locked,return true,else false
    • remainTimeToLiveAsync

      public RFuture<Long> remainTimeToLiveAsync()
      Description copied from interface: RExpirableAsync
      Returns remaining time of the object in milliseconds.
      Specified by:
      remainTimeToLiveAsync in interface RExpirableAsync
      Specified by:
      remainTimeToLiveAsync in interface RLockAsync
      Returns:
      time in milliseconds -2 if the key does not exist. -1 if the key exists but has no associated expire.
    • expire

      public boolean expire(long timeToLive, TimeUnit timeUnit)
      Description copied from interface: RExpirable
      Specified by:
      expire in interface RExpirable
      Parameters:
      timeToLive - - timeout before object will be deleted
      timeUnit - - timeout time unit
      Returns:
      true if the timeout was set and false if not
    • expireAsync

      public RFuture<Boolean> expireAsync(long timeToLive, TimeUnit timeUnit)
      Description copied from interface: RExpirableAsync
      Specified by:
      expireAsync in interface RExpirableAsync
      Parameters:
      timeToLive - - timeout before object will be deleted
      timeUnit - - timeout time unit
      Returns:
      true if the timeout was set and false if not
    • expireAt

      public boolean expireAt(long timestamp)
      Description copied from interface: RExpirable
      Specified by:
      expireAt in interface RExpirable
      Parameters:
      timestamp - - expire date in milliseconds (Unix timestamp)
      Returns:
      true if the timeout was set and false if not
    • expireAtAsync

      public RFuture<Boolean> expireAtAsync(long timestamp)
      Description copied from interface: RExpirableAsync
      Specified by:
      expireAtAsync in interface RExpirableAsync
      Parameters:
      timestamp - - expire date in milliseconds (Unix timestamp)
      Returns:
      true if the timeout was set and false if not
    • expire

      public boolean expire(Instant instant)
      Description copied from interface: RExpirable
      Sets an expiration date for this object. When expire date comes the key will automatically be deleted.
      Specified by:
      expire in interface RExpirable
      Parameters:
      instant - expire date
      Returns:
      true if the timeout was set and false if not
    • expireIfSet

      public boolean expireIfSet(Instant time)
      Description copied from interface: RExpirable
      Sets an expiration date for this object only if it has been already set. When expire date comes the object will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfSet in interface RExpirable
      Parameters:
      time - expire date
      Returns:
      true if the timeout was set and false if not
    • expireIfSetAsync

      public RFuture<Boolean> expireIfSetAsync(Instant time)
      Description copied from interface: RExpirableAsync
      Sets an expiration date for this object only if it has been already set. When expire date comes the object will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfSetAsync in interface RExpirableAsync
      Parameters:
      time - expire date
      Returns:
      true if the timeout was set and false if not
    • expireIfNotSet

      public boolean expireIfNotSet(Instant time)
      Description copied from interface: RExpirable
      Sets an expiration date for this object only if it hasn't been set before. When expire date comes the object will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfNotSet in interface RExpirable
      Parameters:
      time - expire date
      Returns:
      true if the timeout was set and false if not
    • expireIfNotSetAsync

      public RFuture<Boolean> expireIfNotSetAsync(Instant time)
      Description copied from interface: RExpirableAsync
      Sets an expiration date for this object only if it hasn't been set before. When expire date comes the object will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfNotSetAsync in interface RExpirableAsync
      Parameters:
      time - expire date
      Returns:
      true if the timeout was set and false if not
    • expireIfGreater

      public boolean expireIfGreater(Instant time)
      Description copied from interface: RExpirable
      Sets an expiration date for this object only if it's greater than expiration date set before. When expire date comes the object will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfGreater in interface RExpirable
      Parameters:
      time - expire date
      Returns:
      true if the timeout was set and false if not
    • expireIfGreaterAsync

      public RFuture<Boolean> expireIfGreaterAsync(Instant time)
      Description copied from interface: RExpirableAsync
      Sets an expiration date for this object only if it's greater than expiration date set before. When expire date comes the object will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfGreaterAsync in interface RExpirableAsync
      Parameters:
      time - expire date
      Returns:
      true if the timeout was set and false if not
    • expireIfLess

      public boolean expireIfLess(Instant time)
      Description copied from interface: RExpirable
      Sets an expiration date for this object only if it's less than expiration date set before. When expire date comes the object will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfLess in interface RExpirable
      Parameters:
      time - expire date
      Returns:
      true if the timeout was set and false if not
    • expireIfLessAsync

      public RFuture<Boolean> expireIfLessAsync(Instant time)
      Description copied from interface: RExpirableAsync
      Sets an expiration date for this object only if it's less than expiration date set before. When expire date comes the object will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfLessAsync in interface RExpirableAsync
      Parameters:
      time - expire date
      Returns:
      true if the timeout was set and false if not
    • expireAsync

      public RFuture<Boolean> expireAsync(Instant instant)
      Description copied from interface: RExpirableAsync
      Set an expire date for object. When expire date comes the key will automatically be deleted.
      Specified by:
      expireAsync in interface RExpirableAsync
      Parameters:
      instant - - expire date
      Returns:
      true if the timeout was set and false if not
    • expire

      public boolean expire(Duration duration)
      Description copied from interface: RExpirable
      Sets a timeout for this object. After the timeout has expired, the key will automatically be deleted.
      Specified by:
      expire in interface RExpirable
      Parameters:
      duration - timeout before object will be deleted
      Returns:
      true if the timeout was set and false if not
    • expireAsync

      public RFuture<Boolean> expireAsync(Duration duration)
      Description copied from interface: RExpirableAsync
      Set a timeout for object. After the timeout has expired, the key will automatically be deleted.
      Specified by:
      expireAsync in interface RExpirableAsync
      Parameters:
      duration - timeout before object will be deleted
      Returns:
      true if the timeout was set and false if not
    • expireAt

      public boolean expireAt(Date timestamp)
      Description copied from interface: RExpirable
      Specified by:
      expireAt in interface RExpirable
      Parameters:
      timestamp - - expire date
      Returns:
      true if the timeout was set and false if not
    • expireAtAsync

      public RFuture<Boolean> expireAtAsync(Date timestamp)
      Description copied from interface: RExpirableAsync
      Specified by:
      expireAtAsync in interface RExpirableAsync
      Parameters:
      timestamp - - expire date
      Returns:
      true if the timeout was set and false if not
    • expireIfSet

      public boolean expireIfSet(Duration duration)
      Description copied from interface: RExpirable
      Sets a timeout for this object only if it has been already set. After the timeout has expired, the key will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfSet in interface RExpirable
      Parameters:
      duration - timeout before object will be deleted
      Returns:
      true if the timeout was set and false if not
    • expireIfSetAsync

      public RFuture<Boolean> expireIfSetAsync(Duration duration)
      Description copied from interface: RExpirableAsync
      Sets a timeout for this object only if it has been already set. After the timeout has expired, the key will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfSetAsync in interface RExpirableAsync
      Parameters:
      duration - timeout before object will be deleted
      Returns:
      true if the timeout was set and false if not
    • expireIfNotSet

      public boolean expireIfNotSet(Duration duration)
      Description copied from interface: RExpirable
      Sets a timeout for this object only if it hasn't been set before. After the timeout has expired, the key will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfNotSet in interface RExpirable
      Parameters:
      duration - timeout before object will be deleted
      Returns:
      true if the timeout was set and false if not
    • expireIfNotSetAsync

      public RFuture<Boolean> expireIfNotSetAsync(Duration duration)
      Description copied from interface: RExpirableAsync
      Sets a timeout for this object only if it hasn't been set before. After the timeout has expired, the key will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfNotSetAsync in interface RExpirableAsync
      Parameters:
      duration - timeout before object will be deleted
      Returns:
      true if the timeout was set and false if not
    • expireIfGreater

      public boolean expireIfGreater(Duration duration)
      Description copied from interface: RExpirable
      Sets a timeout for this object only if it's greater than timeout set before. After the timeout has expired, the key will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfGreater in interface RExpirable
      Parameters:
      duration - timeout before object will be deleted
      Returns:
      true if the timeout was set and false if not
    • expireIfGreaterAsync

      public RFuture<Boolean> expireIfGreaterAsync(Duration duration)
      Description copied from interface: RExpirableAsync
      Sets a timeout for this object only if it's greater than timeout set before. After the timeout has expired, the key will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfGreaterAsync in interface RExpirableAsync
      Parameters:
      duration - timeout before object will be deleted
      Returns:
      true if the timeout was set and false if not
    • expireIfLess

      public boolean expireIfLess(Duration duration)
      Description copied from interface: RExpirable
      Sets a timeout for this object only if it's less than timeout set before. After the timeout has expired, the key will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfLess in interface RExpirable
      Parameters:
      duration - timeout before object will be deleted
      Returns:
      true if the timeout was set and false if not
    • expireIfLessAsync

      public RFuture<Boolean> expireIfLessAsync(Duration duration)
      Description copied from interface: RExpirableAsync
      Sets a timeout for this object only if it's less than timeout set before. After the timeout has expired, the key will automatically be deleted.

      Requires Redis 7.0.0 and higher.

      Specified by:
      expireIfLessAsync in interface RExpirableAsync
      Parameters:
      duration - timeout before object will be deleted
      Returns:
      true if the timeout was set and false if not
    • clearExpire

      public boolean clearExpire()
      Description copied from interface: RExpirable
      Clear an expire timeout or expire date for object.
      Specified by:
      clearExpire in interface RExpirable
      Returns:
      true if timeout was removed false if object does not exist or does not have an associated timeout
    • clearExpireAsync

      public RFuture<Boolean> clearExpireAsync()
      Description copied from interface: RExpirableAsync
      Clear an expire timeout or expire date for object in async mode. Object will not be deleted.
      Specified by:
      clearExpireAsync in interface RExpirableAsync
      Returns:
      true if the timeout was cleared and false if not
    • getExpireTime

      public long getExpireTime()
      Description copied from interface: RExpirable
      Returns expiration time of the object as the absolute Unix expiration timestamp in milliseconds.

      Requires Redis 7.0.0 and higher.

      Specified by:
      getExpireTime in interface RExpirable
      Returns:
      Unix time in milliseconds -2 if the key does not exist. -1 if the key exists but has no associated expiration time.
    • getExpireTimeAsync

      public RFuture<Long> getExpireTimeAsync()
      Description copied from interface: RExpirableAsync
      Returns expiration time of the object as the absolute Unix expiration timestamp in milliseconds.

      Requires Redis 7.0.0 and higher.

      Specified by:
      getExpireTimeAsync in interface RExpirableAsync
      Returns:
      Unix time in milliseconds -2 if the key does not exist. -1 if the key exists but has no associated expiration time.
    • expireAsync

      protected RFuture<Boolean> expireAsync(long timeToLive, TimeUnit timeUnit, String param, String... keys)
    • expireAtAsync

      protected RFuture<Boolean> expireAtAsync(long timestamp, String param, String... keys)
    • clearExpireAsync

      protected RFuture<Boolean> clearExpireAsync(String... keys)