![JAR search and dependency download from the Maven repository](/logo.png)
org.apache.hadoop.mapred.TaskTrackerAction Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hadoop-core Show documentation
Show all versions of hadoop-core Show documentation
Hadoop is the distributed computing framework of Apache; hadoop-core contains
the filesystem, job tracker and map/reduce modules
The newest version!
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.hadoop.mapred;
import java.io.DataInput;
import java.io.DataOutput;
import java.io.IOException;
import org.apache.hadoop.io.Writable;
import org.apache.hadoop.io.WritableUtils;
/**
* A generic directive from the {@link org.apache.hadoop.mapred.JobTracker}
* to the {@link org.apache.hadoop.mapred.TaskTracker} to take some 'action'.
*
*/
public abstract class TaskTrackerAction implements Writable {
private Writable extensible = null;
/**
* Ennumeration of various 'actions' that the {@link JobTracker}
* directs the {@link TaskTracker} to perform periodically.
*
*/
public static enum ActionType {
/** Launch a new task. */
LAUNCH_TASK,
/** Kill a task. */
KILL_TASK,
/** Kill any tasks of this job and cleanup. */
KILL_JOB,
/** Reinitialize the tasktracker. */
REINIT_TRACKER,
/** Ask a task to save its output. */
COMMIT_TASK
};
/**
* A factory-method to create objects of given {@link ActionType}.
* @param actionType the {@link ActionType} of object to create.
* @return an object of {@link ActionType}.
*/
public static TaskTrackerAction createAction(ActionType actionType) {
TaskTrackerAction action = null;
switch (actionType) {
case LAUNCH_TASK:
{
action = new LaunchTaskAction();
}
break;
case KILL_TASK:
{
action = new KillTaskAction();
}
break;
case KILL_JOB:
{
action = new KillJobAction();
}
break;
case REINIT_TRACKER:
{
action = new ReinitTrackerAction();
}
break;
case COMMIT_TASK:
{
action = new CommitTaskAction();
}
break;
}
return action;
}
private ActionType actionType;
protected TaskTrackerAction(ActionType actionType) {
this.actionType = actionType;
}
protected TaskTrackerAction(ActionType actionType, Writable extensible) {
this.actionType = actionType;
this.extensible = extensible;
}
/**
* Return the {@link ActionType}.
* @return the {@link ActionType}.
*/
ActionType getActionId() {
return actionType;
}
public void write(DataOutput out) throws IOException {
WritableUtils.writeEnum(out, actionType);
String className = "";
if (extensible == null) {
WritableUtils.writeString(out, className);
return;
}
className = extensible.getClass().getCanonicalName();
WritableUtils.writeString(out, className);
extensible.write(out);
}
public void readFields(DataInput in) throws IOException {
actionType = WritableUtils.readEnum(in, ActionType.class);
String className = WritableUtils.readString(in);
if ("".equals(className)) {
return;
}
try {
Class> clazz = Class.forName(className);
extensible = (Writable)(clazz.newInstance());
} catch (ClassNotFoundException e) {
throw new IOException(e);
} catch (InstantiationException e) {
throw new IOException(e);
} catch (IllegalAccessException e) {
throw new IOException(e);
}
extensible.readFields(in);
}
public void setExtensible(Writable extensible) {
this.extensible = extensible;
}
public Writable getExtensible() {
return extensible;
}
@Override
public String toString() {
return actionType.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy