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

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

package org.infinispan.statetransfer;

import org.infinispan.commons.CacheException;

/**
 * An exception signalling that a command should be retried because it was executed with an outdated
 * topology.
 * 

* This can happen for non-tx caches, if the primary owner doesn't respond (either because it left the * cluster or because this particular cache is no longer running). * * @author Dan Berindei * @since 6.0 */ public class OutdatedTopologyException extends CacheException { public final int requestedTopologyId; @SuppressWarnings("ThrowableInstanceNeverThrown") private static final OutdatedTopologyException CACHED = new OutdatedTopologyException(); private OutdatedTopologyException() { super("Topology changed while handling command", null, false, false); requestedTopologyId = -1; } public OutdatedTopologyException(String msg) { super(msg, null, false, false); requestedTopologyId = -1; } /** * Request retrying the command in explicitly set topology (or later one). * @param requestedTopologyId */ public OutdatedTopologyException(int requestedTopologyId) { super(null, null, false, false); this.requestedTopologyId = requestedTopologyId; } /** * A cached instance of {@link OutdatedTopologyException}. *

* This exception has not stack trace information and it should be used internally to notify a topology change while * handle a command. *

* It avoids the cost associated to create and collect the stack when it isn't needed. * * @return a cached instance of {@link OutdatedTopologyException}. */ public static OutdatedTopologyException getCachedInstance() { return CACHED; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy