org.infinispan.xsite.statetransfer.XSiteStateProvider Maven / Gradle / Ivy
package org.infinispan.xsite.statetransfer;
import java.util.Collection;
import org.infinispan.remoting.transport.Address;
/**
* It contains the logic to send state to another site.
*
* @author Pedro Ruivo
* @since 7.0
*/
public interface XSiteStateProvider {
/**
* It notifies this node to start sending state to the remote site. Also, it should keep information about which node
* requested the state transfer in order to send back the notification when finishes.
*
* @param siteName the remote site name.
* @param requestor the requestor.
* @param minTopologyId the topology id to wait before start sending the state.
*/
void startStateTransfer(String siteName, Address requestor, int minTopologyId);
/**
* It cancels the state transfer for the remote site. If no state transfer is available, it should do nothing.
*
* @param siteName the remote site name.
*/
void cancelStateTransfer(String siteName);
/**
* @return a site name collection with the sites in which this cache is sending state.
*/
Collection getCurrentStateSending();
/**
* @return a site name collection with sites in which the coordinator is not in the {@code currentMembers}.
*/
Collection getSitesMissingCoordinator(Collection currentMembers);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy