org.gridgain.grid.compute.GridComputeJob Maven / Gradle / Ivy
/*
Copyright (C) GridGain Systems. All Rights Reserved.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
/* _________ _____ __________________ _____
* __ ____/___________(_)______ /__ ____/______ ____(_)_______
* _ / __ __ ___/__ / _ __ / _ / __ _ __ `/__ / __ __ \
* / /_/ / _ / _ / / /_/ / / /_/ / / /_/ / _ / _ / / /
* \____/ /_/ /_/ \_,__/ \____/ \__,_/ /_/ /_/ /_/
*/
package org.gridgain.grid.compute;
import org.gridgain.grid.*;
import org.gridgain.grid.resources.*;
import org.gridgain.grid.spi.collision.*;
import org.jetbrains.annotations.*;
import java.io.*;
import java.util.*;
/**
* Defines executable unit for {@link GridComputeTask}.
* Description
* Grid job is an executable unit of {@link GridComputeTask}. Grid task gets split into jobs
* when {@link GridComputeTask#map(List, Object)} method is called. This method returns
* all jobs for the task mapped to their corresponding grid nodes for execution. Grid
* will then serialize this jobs and send them to requested nodes for execution.
* When a node receives a request to execute a job, the following sequence of events
* takes place:
*
* -
* If collision SPI is defined, then job gets put on waiting list which is passed to underlying
* {@link GridCollisionSpi} SPI. Otherwise job will be submitted to the executor
* service responsible for job execution immediately upon arrival.
*
* -
* If collision SPI is configured, then it will decide one of the following scheduling policies:
*
* -
* Job will be kept on waiting list. In this case, job will not get a
* chance to execute until next time the Collision SPI is called.
*
* -
* Job will be moved to active list. In this case system will proceed
* with job execution.
*
* -
* Job will be rejected. In this case the {@link GridComputeJobResult} passed into
* {@link GridComputeTask#result(GridComputeJobResult, List)} method will contain
* {@link GridComputeExecutionRejectedException} exception. If you are using any
* of the task adapters shipped with GridGain, then job will be failed
* over automatically for execution on another node.
*
*
*
* -
* For activated jobs, an instance of distributed task session (see {@link GridComputeTaskSession})
* will be injected.
*
* -
* System will execute the job by calling {@link GridComputeJob#execute()} method.
*
* -
* If job gets cancelled while executing then {@link GridComputeJob#cancel()}
* method will be called. Note that just like with {@link Thread#interrupt()}
* method, grid job cancellation serves as a hint that a job should stop
* executing or exhibit some other user defined behavior. Generally it is
* up to a job to decide whether it wants to react to cancellation or
* ignore it. Job cancellation can happen for several reasons:
*
* - Collision SPI cancelled an active job.
* - Parent task has completed without waiting for this job's result.
* - User cancelled task by calling {@link GridComputeTaskFuture#cancel()} method.
*
*
* -
* Once job execution is complete, the return value will be sent back to parent
* task and will be passed into {@link GridComputeTask#result(GridComputeJobResult, List)}
* method via {@link GridComputeJobResult} instance. If job execution resulted
* in a checked exception, then {@link GridComputeJobResult#getException()} method
* will contain that exception. If job execution threw a runtime exception
* or error, then it will be wrapped into {@link GridComputeUserUndeclaredException}
* exception.
*
*
*
*
Resource Injection
* Grid job implementation can be injected using IoC (dependency injection) with
* grid resources. Both, field and method based injection are supported.
* The following grid resources can be injected:
*
* - {@link GridTaskSessionResource}
* - {@link GridJobContextResource}
* - {@link GridInstanceResource}
* - {@link GridLoggerResource}
* - {@link GridHomeResource}
* - {@link GridExecutorServiceResource}
* - {@link GridLocalNodeIdResource}
* - {@link GridMBeanServerResource}
* - {@link GridMarshallerResource}
* - {@link GridSpringApplicationContextResource}
* - {@link GridSpringResource}
*
* Refer to corresponding resource documentation for more information.
*
*
GridComputeJobAdapter
* GridGain comes with convenience {@link GridComputeJobAdapter} adapter that provides
* default empty implementation for {@link GridComputeJob#cancel()} method and also
* allows user to set and get job argument, if there is one.
*
*
Distributed Session Attributes
* Jobs can communicate with parent task and with other job siblings from the same
* task by setting session attributes (see {@link GridComputeTaskSession}). Other jobs
* can wait for an attribute to be set either synchronously or asynchronously.
* Such functionality allows jobs to synchronize their execution with other jobs
* at any point and can be useful when other jobs within task need to be made aware
* of certain event or state change that occurred during job execution.
*
* Distributed task session can be injected into {@link GridComputeJob} implementation
* using {@link GridTaskSessionResource @GridTaskSessionResource} annotation.
* Both, field and method based injections are supported. Refer to
* {@link GridComputeTaskSession} documentation for more information on session functionality.
*
*
Saving Checkpoints
* Long running jobs may wish to save intermediate checkpoints to protect themselves
* from failures. There are three checkpoint management methods:
*
* - {@link GridComputeTaskSession#saveCheckpoint(String, Object, GridComputeTaskSessionScope, long)}
* - {@link GridComputeTaskSession#loadCheckpoint(String)}
* - {@link GridComputeTaskSession#removeCheckpoint(String)}
*
* Jobs that utilize checkpoint functionality should attempt to load a check
* point at the beginning of execution. If a {@code non-null} value is returned,
* then job can continue from where it failed last time, otherwise it would start
* from scratch. Throughout it's execution job should periodically save its
* intermediate state to avoid starting from scratch in case of a failure.
*/
public interface GridComputeJob extends Serializable {
/**
* This method is called when system detects that completion of this
* job can no longer alter the overall outcome (for example, when parent task
* has already reduced the results). Job is also cancelled when
* {@link GridComputeTaskFuture#cancel()} is called.
*
* Note that job cancellation is only a hint, and just like with
* {@link Thread#interrupt()} method, it is really up to the actual job
* instance to gracefully finish execution and exit.
*/
public void cancel();
/**
* Executes this job.
*
* @return Job execution result (possibly {@code null}). This result will be returned
* in {@link GridComputeJobResult#getData()} method passed into
* {@link GridComputeTask#result(GridComputeJobResult, List)} task method on caller node.
* @throws GridException If job execution caused an exception. This exception will be
* returned in {@link GridComputeJobResult#getException()} method passed into
* {@link GridComputeTask#result(GridComputeJobResult, List)} task method on caller node.
* If execution produces a {@link RuntimeException} or {@link Error}, then
* it will be wrapped into {@link GridException}.
*/
@Nullable public Object execute() throws GridException;
}