org.infinispan.xsite.BackupSender Maven / Gradle / Ivy
package org.infinispan.xsite;
import java.util.Map;
import javax.transaction.Transaction;
import org.infinispan.commands.VisitableCommand;
import org.infinispan.commands.tx.CommitCommand;
import org.infinispan.commands.tx.PrepareCommand;
import org.infinispan.commands.tx.RollbackCommand;
import org.infinispan.commands.write.WriteCommand;
import org.infinispan.remoting.transport.BackupResponse;
import org.infinispan.transaction.impl.AbstractCacheTransaction;
/**
* Component responsible with sending backup data to remote sites. The send operation is executed async, it's up to the
* caller to wait on the returned {@link BackupResponse} in the case it wants an sync call.
*
* @see BackupResponse
* @author Mircea Markus
* @since 5.2
*/
public interface BackupSender {
/**
* Prepares a transaction on the remote site.
*/
BackupResponse backupPrepare(PrepareCommand command, AbstractCacheTransaction cacheTransaction) throws Exception;
/**
* Processes the responses of a backup command. It might throw an exception in the case the replication to the
* remote site fail, based on the configured {@link CustomFailurePolicy}.
*/
void processResponses(BackupResponse backupResponse, VisitableCommand command) throws Throwable;
BackupResponse backupWrite(WriteCommand command) throws Exception;
BackupResponse backupCommit(CommitCommand command) throws Exception;
BackupResponse backupRollback(RollbackCommand command) throws Exception;
void processResponses(BackupResponse backupResponse, VisitableCommand command, Transaction transaction) throws Throwable;
OfflineStatus getOfflineStatus(String siteName);
/**
* Returns a Map having as entries the site names and as value Boolean.TRUE if the site is online and Boolean.FALSE
* if it is offline.
*/
Map status();
enum BringSiteOnlineResponse {
NO_SUCH_SITE,
ALREADY_ONLINE,
BROUGHT_ONLINE
}
/**
* Brings a site with the given name back online.
*/
BringSiteOnlineResponse bringSiteOnline(String siteName);
enum TakeSiteOfflineResponse {
NO_SUCH_SITE,
ALREADY_OFFLINE,
TAKEN_OFFLINE
}
TakeSiteOfflineResponse takeSiteOffline(String siteName);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy