
org.infinispan.distexec.FailoverContext Maven / Gradle / Ivy
/*
* JBoss, Home of Professional Open Source
* Copyright 2012 Red Hat Inc. and/or its affiliates and other contributors
* as indicated by the @author tag. All rights reserved.
* See the copyright.txt in the distribution for a
* full listing of individual contributors.
*
* This copyrighted material is made available to anyone wishing to use,
* modify, copy, or redistribute it subject to the terms and conditions
* of the GNU Lesser General Public License, v. 2.1.
* This program is distributed in the hope that it will be useful, but WITHOUT A
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
* PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
* You should have received a copy of the GNU Lesser General Public License,
* v.2.1 along with this distribution; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
* MA 02110-1301, USA.
*/
package org.infinispan.distexec;
import java.util.List;
import org.infinispan.remoting.transport.Address;
/**
* As {@link DistributedTask} might potentially fail on subset of executing nodes FailureContext
* provides details of such task failure. FailureContext has a scope of a node where the task
* failed.
*
* @author Vladimir Blagojevic
* @since 5.2
*/
public interface FailoverContext {
/**
* Returns an Address of the node where the task failed
*
* @return the Address of the failed execution location
*/
Address executionFailureLocation();
/**
* Returns a list of candidates for possible repeated execution governed by installed
* {@link DistributedTaskFailoverPolicy}
*
* @return an Address list of possible execution candidates
*/
List executionCandidates();
/**
* Returns the Throwable which was the cause of the task failure. This includes both system
* exception related to Infinispan transient failures (node crash, transient errors etc) as well
* as application level exceptions. Returned Throwable will most likely contain the chain of
* Exceptions that interested clients can inspect and, if desired, find the root cause of the
* returned Throwable
*
* @see {@link Throwable#getCause()} API to recursively traverse the Exception chain
*
* @return the Throwable that caused task failure on the particular Infinispan node
*/
Throwable cause();
/**
* Returns a list of input keys for this task. Note that this method does not return all of the
* keys used as input for {@link DistributedTask} but rather only the input keys used as input
* for a part of that task where the execution failed
*
* @param
* @return the list of input keys if any
*/
List inputKeys();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy