All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.infinispan.statetransfer.StateTransferLock Maven / Gradle / Ivy

There is a newer version: 15.1.0.Dev04
Show newest version
package org.infinispan.statetransfer;

import java.util.concurrent.CompletionStage;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.TimeoutException;

import org.infinispan.commons.CacheException;
import org.infinispan.configuration.cache.ClusteringConfiguration;
import org.infinispan.configuration.cache.StateTransferConfiguration;
import org.infinispan.factories.scopes.Scope;
import org.infinispan.factories.scopes.Scopes;

/**
 * We use the state transfer lock for three different things:
 * 
    *
  1. We don't want to execute a command until we have the transaction table for that topology id. * For this purpose it works like a latch, commands wait on the latch and state transfer opens the latch * when it has received all the transaction data for that topology id.
  2. *
  3. Do not write anything to the data container in a segment that we have already removed. * For this purpose, ownership checks and data container writes acquire a shared lock, and * the segment removal acquires an exclusive lock.
  4. *
  5. We want to handle state requests only after we have installed the same topology id, because * this guarantees that we also have installed the corresponding view id and we have all the joiners * in our JGroups view. Here it works like a latch as well, state requests wait on the latch and state * transfer opens the latch when it has received all the transaction data for that topology id.
  6. *
* * @author [email protected] * @author Dan Berindei * @since 5.2 */ @Scope(Scopes.NAMED_CACHE) public interface StateTransferLock { // topology change lock void acquireExclusiveTopologyLock(); void releaseExclusiveTopologyLock(); void acquireSharedTopologyLock(); void releaseSharedTopologyLock(); // transaction data latch void notifyTransactionDataReceived(int topologyId); /** * @return a stage that completes successfully when topology {@code expectedTopologyId} * has been installed and transaction data has been received, * or with a {@link org.infinispan.util.concurrent.TimeoutException} * after {@link ClusteringConfiguration#remoteTimeout()} expires. */ CompletionStage transactionDataFuture(int expectedTopologyId); boolean transactionDataReceived(int expectedTopologyId); // topology installation latch // TODO move this to Cluster/LocalTopologyManagerImpl and don't start requesting state until every node has the jgroups view with the local node void notifyTopologyInstalled(int topologyId); /** * @return a stage that completes successfully when topology {@code expectedTopologyId} * has been installed, or with a {@link org.infinispan.util.concurrent.TimeoutException} * after {@link StateTransferConfiguration#timeout()} expires. */ CompletionStage topologyFuture(int expectedTopologyId); @Deprecated default void waitForTopology(int expectedTopologyId, long timeout, TimeUnit unit) throws InterruptedException, TimeoutException { try { CompletionStage topologyFuture = topologyFuture(expectedTopologyId); topologyFuture.toCompletableFuture().get(timeout, unit); } catch (ExecutionException e) { throw new CacheException(e.getCause()); } } boolean topologyReceived(int expectedTopologyId); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy