Package org.apache.ignite.compute
Interface ComputeTask<T,R>
- 
- Type Parameters:
- T- Type of the task argument that is passed into- map(List, Object)method.
- R- Type of the task result returning from- reduce(List)method.
 - All Superinterfaces:
- Serializable
 - All Known Implementing Classes:
- ComputeTaskAdapter,- ComputeTaskSplitAdapter
 
 public interface ComputeTask<T,R> extends Serializable Grid task interface defines a task that can be executed on the grid. Grid task is responsible for splitting business logic into multiple grid jobs, receiving results from individual grid jobs executing on remote nodes, and reducing (aggregating) received jobs' results into final grid task result.Grid Task Execution Sequence- 
      Upon request to execute a grid task with given task name system will find
      deployed task with given name. Task needs to be deployed prior to execution
      (see IgniteCompute.localDeployTask(Class, ClassLoader)method), however if task does not specify its name explicitly via@ComputeTaskNameannotation, it will be auto-deployed first time it gets executed.
- 
      System will create new distributed task session (see ComputeTaskSession).
- 
      System will inject all annotated resources (including task session) into grid task instance.
      See org.apache.ignite.resourcespackage for the list of injectable resources.
- 
      System will apply map(List, Object). This method is responsible for splitting business logic of grid task into multiple grid jobs (units of execution) and mapping them to grid nodes. Methodmap(List, Object)returns a map of with grid jobs as keys and grid node as values.
- System will send mapped grid jobs to their respective nodes.
- 
      Upon arrival on the remote node a grid job will be handled by collision SPI
      (see CollisionSpi) which will determine how a job will be executed on the remote node (immediately, buffered or canceled).
- 
      Once job execution results become available method result(ComputeJobResult, List)will be called for each received job result. The policy returned by this method will determine the way task reacts to every job result:- 
          If ComputeJobResultPolicy.WAITpolicy is returned, task will continue to wait for other job results. If this result is the last job result, thenreduce(List)method will be called.
- 
          If ComputeJobResultPolicy.REDUCEpolicy is returned, then methodreduce(List)will be called right away without waiting for other jobs' completion (all remaining jobs will receive a cancel request).
- 
          If ComputeJobResultPolicy.FAILOVERpolicy is returned, then job will be failed over to another node for execution. The node to which job will get failed over is decided byFailoverSpiSPI implementation. Note that if you useComputeTaskAdapteradapter forComputeTaskimplementation, then it will automatically fail jobs to another node for 2 known failure cases:- 
              Job has failed due to node crash. In this case ComputeJobResult.getException()method will return an instance ofClusterTopologyExceptionexception.
- 
              Job execution was rejected, i.e. remote node has cancelled job before it got
              a chance to execute, while it still was on the waiting list. In this case
              ComputeJobResult.getException()method will return an instance ofComputeExecutionRejectedExceptionexception.
 
- 
              Job has failed due to node crash. In this case 
 
- 
          If 
- 
      Once all results are received or result(ComputeJobResult, List)method returnedComputeJobResultPolicy.REDUCEpolicy, methodreduce(List)is called to aggregate received results into one final result. Once this method is finished the execution of the grid task is complete. This result will be returned to the user throughComputeTaskFuture.get()method.
 Continuous Job MapperFor cases when jobs within split are too large to fit in memory at once or when simply not all jobs in task are known duringmap(List, Object)step, useComputeTaskContinuousMapperto continuously stream jobs from task even aftermap(...)step is complete. Usually with continuous mapper the number of jobs within task may grow too large - in this case it may make sense to use it in combination with@ComputeTaskNoResultCacheannotation.Task Result CachingSometimes job results are too large or task simply has too many jobs to keep track of which may hinder performance. In such cases it may make sense to disable task result caching by attaching@ComputeTaskNoResultCacheannotation to task class, and processing all results as they come inresult(ComputeJobResult, List)method. When Ignite sees this annotation it will disable tracking of job results and list of all job results passed intoresult(ComputeJobResult, List)orreduce(List)methods will always be empty. Note that list of job siblings onComputeTaskSessionwill also be empty to prevent number of job siblings from growing as well.Resource InjectionGrid task implementation can be injected using IoC (dependency injection) with ignite resources. Both, field and method based injection are supported. The following ignite resources can be injected:- TaskSessionResource
- IgniteInstanceResource
- LoggerResource
- SpringApplicationContextResource
- SpringResource
 Grid Task AdaptersComputeTaskcomes with several convenience adapters to make the usage easier:- 
 ComputeTaskAdapterprovides default implementation forresult(ComputeJobResult, List)method which provides automatic fail-over to another node if remote job has failed due to node crash (detected byClusterTopologyExceptionexception) or due to job execution rejection (detected byComputeExecutionRejectedExceptionexception). Here is an example of how a you would implement your task usingComputeTaskAdapter:public class MyFooBarTask extends ComputeTaskAdapter<String, String> { // Inject load balancer. @LoadBalancerResource ComputeLoadBalancer balancer; // Map jobs to grid nodes. public Map<? extends ComputeJob, ClusterNode> map(List<ClusterNode> subgrid, String arg) throws IgniteCheckedException { Map<MyFooBarJob, ClusterNode> jobs = new HashMap<MyFooBarJob, ClusterNode>(subgrid.size()); // In more complex cases, you can actually do // more complicated assignments of jobs to nodes. for (int i = 0; i < subgrid.size(); i++) { // Pick the next best balanced node for the job. jobs.put(new MyFooBarJob(arg), balancer.getBalancedNode()) } return jobs; } // Aggregate results into one compound result. public String reduce(List<ComputeJobResult> results) throws IgniteCheckedException { // For the purpose of this example we simply // concatenate string representation of every // job result StringBuilder buf = new StringBuilder(); for (ComputeJobResult res : results) { // Append string representation of result // returned by every job. buf.append(res.getData().string()); } return buf.string(); } }
- 
 ComputeTaskSplitAdapterhides the job-to-node mapping logic from user and provides convenientComputeTaskSplitAdapter.split(int, Object)method for splitting task into sub-jobs in homogeneous environments. Here is an example of how you would implement your task usingComputeTaskSplitAdapter:public class MyFooBarTask extends ComputeTaskSplitAdapter<Object, String> { @Override protected Collection<? extends ComputeJob> split(int gridSize, Object arg) throws IgniteCheckedException { List<MyFooBarJob> jobs = new ArrayList<MyFooBarJob>(gridSize); for (int i = 0; i < gridSize; i++) { jobs.add(new MyFooBarJob(arg)); } // Node assignment via load balancer // happens automatically. return jobs; } // Aggregate results into one compound result. public String reduce(List<ComputeJobResult> results) throws IgniteCheckedException { // For the purpose of this example we simply // concatenate string representation of every // job result StringBuilder buf = new StringBuilder(); for (ComputeJobResult res : results) { // Append string representation of result // returned by every job. buf.append(res.getData().string()); } return buf.string(); } }
 
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Modifier and Type Method Description @NotNull Map<? extends ComputeJob,ClusterNode>map(List<ClusterNode> subgrid, T arg)This method is called to map or split grid task into multiple grid jobs.Rreduce(List<ComputeJobResult> results)Reduces (or aggregates) results received so far into one compound result to be returned to caller viaComputeTaskFuture.get()method.ComputeJobResultPolicyresult(ComputeJobResult res, List<ComputeJobResult> rcvd)Asynchronous callback invoked every time a result from remote execution is received.
 
- 
- 
- 
Method Detail- 
map@NotNull @NotNull Map<? extends ComputeJob,ClusterNode> map(List<ClusterNode> subgrid, @Nullable T arg) throws IgniteException This method is called to map or split grid task into multiple grid jobs. This is the first method that gets called when task execution starts.- Parameters:
- arg- Task execution argument. Can be- null. This is the same argument as the one passed into- Grid#execute(...)methods.
- subgrid- Nodes available for this task execution. Note that order of nodes is guaranteed to be randomized by container. This ensures that every time you simply iterate through grid nodes, the order of nodes will be random which over time should result into all nodes being used equally.
- Returns:
- Map of grid jobs assigned to subgrid node. Unless ComputeTaskContinuousMapperis injected into task, ifnullor empty map is returned, exception will be thrown.
- Throws:
- IgniteException- If mapping could not complete successfully. This exception will be thrown out of- ComputeTaskFuture.get()method.
 
 - 
resultComputeJobResultPolicy result(ComputeJobResult res, List<ComputeJobResult> rcvd) throws IgniteException Asynchronous callback invoked every time a result from remote execution is received. It is ultimately upto this method to return a policy based on which the system will either wait for more results, reduce results received so far, or failover this job to another node. SeeComputeJobResultPolicyfor more information about result policies.- Parameters:
- res- Received remote grid executable result.
- rcvd- All previously received results. Note that if task class has- ComputeTaskNoResultCacheannotation, then this list will be empty.
- Returns:
- Result policy that dictates how to process further upcoming job results.
- Throws:
- IgniteException- If handling a job result caused an error. This exception will be thrown out of- ComputeTaskFuture.get()method.
 
 - 
reduce@Nullable R reduce(List<ComputeJobResult> results) throws IgniteException Reduces (or aggregates) results received so far into one compound result to be returned to caller viaComputeTaskFuture.get()method.Note, that if some jobs did not succeed and could not be failed over then the list of results passed into this method will include the failed results. Otherwise, failed results will not be in the list. - Parameters:
- results- Received results of broadcasted remote executions. Note that if task class has- ComputeTaskNoResultCacheannotation, then this list will be empty.
- Returns:
- Grid job result constructed from results of remote executions.
- Throws:
- IgniteException- If reduction or results caused an error. This exception will be thrown out of- ComputeTaskFuture.get()method.
 
 
- 
 
-