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

org.infinispan.xsite.BackupReceiver Maven / Gradle / Ivy

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

import java.util.concurrent.CompletionStage;

import org.infinispan.commands.VisitableCommand;
import org.infinispan.factories.scopes.Scope;
import org.infinispan.factories.scopes.Scopes;
import org.infinispan.metadata.Metadata;
import org.infinispan.metadata.impl.IracMetadata;
import org.infinispan.xsite.commands.XSiteStateTransferFinishReceiveCommand;
import org.infinispan.xsite.commands.XSiteStateTransferStartReceiveCommand;
import org.infinispan.xsite.statetransfer.XSiteStatePushCommand;

/**
 * Component present on a backup site that manages the backup information and logic.
 *
 * @see ClusteredCacheBackupReceiver
 * @author Mircea Markus
 * @since 5.2
 */
@Scope(Scopes.NAMED_CACHE)
public interface BackupReceiver {

    CompletionStage handleRemoteCommand(VisitableCommand command, boolean preserveOrder);

   /**
    * Updates the key with the value from a remote site.
    * 

* If a conflict occurs, the update can be discarded. * * @param key The key to update. * @param value The new value. * @param metadata The new {@link Metadata}. * @param iracMetadata The {@link IracMetadata} for conflict resolution. * @return A {@link CompletionStage} that is completed when the update is apply in the cluster or is discarded. */ CompletionStage putKeyValue(Object key, Object value, Metadata metadata, IracMetadata iracMetadata); /** * Deletes the key. *

* This is a request from the remote site and the removal can be discarded if a conflict happens. * * @param key The key to delete. * @param iracMetadata The {@link IracMetadata} for conflict resolution. * @param expiration {@code true} if it is to remove an expired key. * @return A {@link CompletionStage} that is completed when the key is deleted or it is discarded. */ CompletionStage removeKey(Object key, IracMetadata iracMetadata, boolean expiration); /** * Clears the cache. *

* This is not safe and it doesn't perform any conflict resolution. * * @return A {@link CompletionStage} that is completed when the cache is cleared. */ CompletionStage clearKeys(); /** * Touches an entry and returns if it was able to or not. * @param key the key of the entry to touch * @return if the entry was touched */ CompletionStage touchEntry(Object key); /** * It handles starting the state transfer from a remote site. The command must be broadcast to the entire cluster in * which the cache exists. */ CompletionStage handleStartReceivingStateTransfer(XSiteStateTransferStartReceiveCommand command); /** * It handles finishing the state transfer from a remote site. The command must be broadcast to the entire cluster in * which the cache exists. */ CompletionStage handleEndReceivingStateTransfer(XSiteStateTransferFinishReceiveCommand command); /** * It handles the state transfer state from a remote site. It is possible to have a single node applying the state or * forward the state to respective primary owners. */ CompletionStage handleStateTransferState(XSiteStatePushCommand cmd); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy