Package org.infinispan.lock.api
Interface ClusteredLock
public interface ClusteredLock
ClusteredLock is a data structure used for concurrent programming between Infinispan instances in cluster mode.
 A typical usage idiom for 
lock() will be :
 
  ClusteredLock lock = clm.get("lock");
  lock.lock()
  .thenRun(() ->
          try {
            // manipulate protected state
          } finally {
              return lock.unlock();
          }
  )
 
 A typical usage idiom for tryLock() will be :
 
  lock.tryLock()
    .thenCompose(result -> {
       if (result) {
        try {
            // manipulate protected state
            } finally {
               return lock.unlock();
            }
       } else {
          // Do something else
       }
    });
 - Since:
- 9.2
- Author:
- Katia Aresti, karesti@redhat.com
- See Also:
- 
Method SummaryModifier and TypeMethodDescriptionisLocked()Returns aCompletableFuture<Boolean>holdingtruewhen the lock is locked andfalsewhen the lock is released.Returns aCompletableFuture<Boolean>holdingtruewhen the lock is owned by the caller andfalsewhen the lock is owned by someone else or it's released.lock()Acquires the lock.tryLock()Acquires the lock only if it is free at the time of invocation.If the lock is available this method returns immediately with theCompletableFutureholding the valuetrue.unlock()Releases the lock.
- 
Method Details- 
lockCompletableFuture<Void> lock()Acquires the lock. If the lock is not available then theCompletableFuturewaits until the lock has been acquired. Currently, there is no maximum time specified for a lock request to fail, so this could cause thread starvation.- Returns:
- a completed CompletableFuturewhen the lock is acquired
- Throws:
- ClusteredLockException- when the lock does not exist
 
- 
tryLockCompletableFuture<Boolean> tryLock()Acquires the lock only if it is free at the time of invocation. Acquires the lock if it is available and returns immediately with with theCompletableFutureholding the valuetrue. If the lock is not available then this method will return immediately with theCompletableFutureholding the valuefalse.- Returns:
- CompletableFuture(true)if the lock was acquired and- CompletableFuture(false)otherwise
- Throws:
- ClusteredLockException- when the lock does not exist
 
- 
tryLockIf the lock is available this method returns immediately with theCompletableFutureholding the valuetrue. If the lock is not available then theCompletableFuturewaits until :- The lock is acquired
- The specified waiting time elapses
 CompletableFuturewill complete with the valuetrue. If the specified waiting time elapses then theCompletableFuturewill complete with the valuefalse. If the time is less than or equal to zero, the method will not wait at all.- Parameters:
- time- , the maximum time to wait for the lock
- unit- , the time unit of the- timeargument
- Returns:
- CompletableFuture(true)if the lock was acquired and- CompletableFuture(false)if the waiting time elapsed before the lock was acquired
- Throws:
- ClusteredLockException- when the lock does not exist
 
- 
unlockCompletableFuture<Void> unlock()Releases the lock. Only the holder of the lock may release the lock.- Returns:
- a completed CompletableFuturewhen the lock is released
- Throws:
- ClusteredLockException- when the lock does not exist
 
- 
isLockedCompletableFuture<Boolean> isLocked()Returns aCompletableFuture<Boolean>holdingtruewhen the lock is locked andfalsewhen the lock is released.- Returns:
- a CompletableFutureholding aBoolean
- Throws:
- ClusteredLockException- when the lock does not exist
 
- 
isLockedByMeCompletableFuture<Boolean> isLockedByMe()Returns aCompletableFuture<Boolean>holdingtruewhen the lock is owned by the caller andfalsewhen the lock is owned by someone else or it's released.- Returns:
- a CompletableFutureholding aBoolean
- Throws:
- ClusteredLockException- when the lock does not exist
 
 
-