|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.apache.hadoop.mapreduce.task.JobContextImpl org.apache.hadoop.mapreduce.Job
@InterfaceAudience.Public @InterfaceStability.Evolving public class Job
The job submitter's view of the Job.
It allows the user to configure the job, submit it, control its execution, and query the state. The set methods only work until the job is submitted, afterwards they will throw an IllegalStateException.
Normally the user creates the application, describes various facets of the
job via Job
and then submits the job and monitor its progress.
Here is an example on how to submit a job:
// Create a new Job Job job = new Job(new Configuration()); job.setJarByClass(MyJob.class); // Specify various job-specific parameters job.setJobName("myjob"); job.setInputPath(new Path("in")); job.setOutputPath(new Path("out")); job.setMapperClass(MyJob.MyMapper.class); job.setReducerClass(MyJob.MyReducer.class); // Submit the job, then poll for progress until the job is complete job.waitForCompletion(true);
Nested Class Summary | |
---|---|
static class |
Job.JobState
|
static class |
Job.TaskStatusFilter
|
Field Summary | |
---|---|
static String |
COMPLETION_POLL_INTERVAL_KEY
Key in mapred-*.xml that sets completionPollInvervalMillis |
static String |
OUTPUT_FILTER
|
static String |
PROGRESS_MONITOR_POLL_INTERVAL_KEY
Key in mapred-*.xml that sets progMonitorPollIntervalMillis |
static String |
SUBMIT_REPLICATION
|
static String |
USED_GENERIC_PARSER
|
Fields inherited from class org.apache.hadoop.mapreduce.task.JobContextImpl |
---|
conf, credentials, ugi |
Constructor Summary | |
---|---|
Job()
Deprecated. |
|
Job(org.apache.hadoop.conf.Configuration conf)
Deprecated. |
|
Job(org.apache.hadoop.conf.Configuration conf,
String jobName)
Deprecated. |
Method Summary | |
---|---|
void |
addArchiveToClassPath(org.apache.hadoop.fs.Path archive)
Add an archive path to the current set of classpath entries. |
void |
addCacheArchive(URI uri)
Add a archives to be localized |
void |
addCacheFile(URI uri)
Add a file to be localized |
void |
addFileToClassPath(org.apache.hadoop.fs.Path file)
Add an file path to the current set of classpath entries It adds the file to cache as well. |
float |
cleanupProgress()
Get the progress of the job's cleanup-tasks, as a float between 0.0 and 1.0. |
void |
createSymlink()
Deprecated. |
boolean |
failTask(TaskAttemptID taskId)
Fail indicated task attempt. |
Cluster |
getCluster()
|
static int |
getCompletionPollInterval(org.apache.hadoop.conf.Configuration conf)
The interval at which waitForCompletion() should check. |
Counters |
getCounters()
Gets the counters for this job. |
long |
getFinishTime()
Get finish time of the job. |
String |
getHistoryUrl()
|
static Job |
getInstance()
Creates a new Job with no particular Cluster . |
static Job |
getInstance(Cluster ignored)
Deprecated. Use getInstance() |
static Job |
getInstance(Cluster ignored,
org.apache.hadoop.conf.Configuration conf)
Deprecated. Use getInstance(Configuration) |
static Job |
getInstance(Cluster cluster,
JobStatus status,
org.apache.hadoop.conf.Configuration conf)
Creates a new Job with no particular Cluster and given
Configuration and JobStatus . |
static Job |
getInstance(org.apache.hadoop.conf.Configuration conf)
Creates a new Job with no particular Cluster and a
given Configuration . |
static Job |
getInstance(org.apache.hadoop.conf.Configuration conf,
String jobName)
Creates a new Job with no particular Cluster and a given jobName. |
static Job |
getInstance(JobStatus status,
org.apache.hadoop.conf.Configuration conf)
Creates a new Job with no particular Cluster and given
Configuration and JobStatus . |
String |
getJobFile()
Get the path of the submitted job configuration. |
String |
getJobName()
The user-specified job name. |
JobStatus.State |
getJobState()
Returns the current state of the Job. |
org.apache.hadoop.mapreduce.JobSubmitter |
getJobSubmitter(org.apache.hadoop.fs.FileSystem fs,
ClientProtocol submitClient)
Only for mocking via unit tests. |
JobPriority |
getPriority()
Get scheduling info of the job. |
static int |
getProgressPollInterval(org.apache.hadoop.conf.Configuration conf)
The interval at which monitorAndPrintJob() prints status |
String |
getSchedulingInfo()
Get scheduling info of the job. |
long |
getStartTime()
Get start time of the job. |
JobStatus |
getStatus()
|
TaskCompletionEvent[] |
getTaskCompletionEvents(int startFrom,
int numEvents)
Get events indicating completion (success/failure) of component tasks. |
String[] |
getTaskDiagnostics(TaskAttemptID taskid)
Gets the diagnostic messages for a given task attempt. |
static Job.TaskStatusFilter |
getTaskOutputFilter(org.apache.hadoop.conf.Configuration conf)
Get the task output filter. |
TaskReport[] |
getTaskReports(TaskType type)
Get the information of the current state of the tasks of a job. |
String |
getTrackingURL()
Get the URL where some job progress information will be displayed. |
boolean |
isComplete()
Check if the job is finished or not. |
boolean |
isRetired()
|
boolean |
isSuccessful()
Check if the job completed successfully. |
boolean |
isUber()
|
void |
killJob()
Kill the running job. |
boolean |
killTask(TaskAttemptID taskId)
Kill indicated task attempt. |
float |
mapProgress()
Get the progress of the job's map-tasks, as a float between 0.0 and 1.0. |
boolean |
monitorAndPrintJob()
Monitor a job and print status in real-time as progress is made and tasks fail. |
float |
reduceProgress()
Get the progress of the job's reduce-tasks, as a float between 0.0 and 1.0. |
void |
setCacheArchives(URI[] archives)
Set the given set of archives |
void |
setCacheFiles(URI[] files)
Set the given set of files |
void |
setCancelDelegationTokenUponJobCompletion(boolean value)
Sets the flag that will allow the JobTracker to cancel the HDFS delegation tokens upon job completion. |
void |
setCombinerClass(Class<? extends Reducer> cls)
Set the combiner class for the job. |
void |
setGroupingComparatorClass(Class<? extends org.apache.hadoop.io.RawComparator> cls)
Define the comparator that controls which keys are grouped together for a single call to Reducer.reduce(Object, Iterable,
org.apache.hadoop.mapreduce.Reducer.Context) |
void |
setInputFormatClass(Class<? extends InputFormat> cls)
Set the InputFormat for the job. |
void |
setJar(String jar)
Set the job jar |
void |
setJarByClass(Class<?> cls)
Set the Jar by finding where a given class came from. |
void |
setJobName(String name)
Set the user-specified job name. |
void |
setJobSetupCleanupNeeded(boolean needed)
Specify whether job-setup and job-cleanup is needed for the job |
void |
setMapOutputKeyClass(Class<?> theClass)
Set the key class for the map output data. |
void |
setMapOutputValueClass(Class<?> theClass)
Set the value class for the map output data. |
void |
setMapperClass(Class<? extends Mapper> cls)
Set the Mapper for the job. |
void |
setMapSpeculativeExecution(boolean speculativeExecution)
Turn speculative execution on or off for this job for map tasks. |
void |
setMaxMapAttempts(int n)
Expert: Set the number of maximum attempts that will be made to run a map task. |
void |
setMaxReduceAttempts(int n)
Expert: Set the number of maximum attempts that will be made to run a reduce task. |
void |
setNumReduceTasks(int tasks)
Set the number of reduce tasks for the job. |
void |
setOutputFormatClass(Class<? extends OutputFormat> cls)
Set the OutputFormat for the job. |
void |
setOutputKeyClass(Class<?> theClass)
Set the key class for the job output data. |
void |
setOutputValueClass(Class<?> theClass)
Set the value class for job outputs. |
void |
setPartitionerClass(Class<? extends Partitioner> cls)
Set the Partitioner for the job. |
void |
setPriority(JobPriority priority)
Set the priority of a running job. |
void |
setProfileEnabled(boolean newValue)
Set whether the system should collect profiler information for some of the tasks in this job? The information is stored in the user log directory. |
void |
setProfileParams(String value)
Set the profiler configuration arguments. |
void |
setProfileTaskRange(boolean isMap,
String newValue)
Set the ranges of maps or reduces to profile. |
void |
setReducerClass(Class<? extends Reducer> cls)
Set the Reducer for the job. |
void |
setReduceSpeculativeExecution(boolean speculativeExecution)
Turn speculative execution on or off for this job for reduce tasks. |
void |
setSortComparatorClass(Class<? extends org.apache.hadoop.io.RawComparator> cls)
Define the comparator that controls how the keys are sorted before they are passed to the Reducer . |
void |
setSpeculativeExecution(boolean speculativeExecution)
Turn speculative execution on or off for this job. |
static void |
setTaskOutputFilter(org.apache.hadoop.conf.Configuration conf,
Job.TaskStatusFilter newValue)
Modify the Configuration to set the task output filter. |
float |
setupProgress()
Get the progress of the job's setup-tasks, as a float between 0.0 and 1.0. |
void |
setUser(String user)
Set the reported username for this job. |
void |
setWorkingDirectory(org.apache.hadoop.fs.Path dir)
Set the current working directory for the default file system. |
void |
submit()
Submit the job to the cluster and return immediately. |
String |
toString()
Dump stats to screen. |
boolean |
waitForCompletion(boolean verbose)
Submit the job to the cluster and wait for it to finish. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Field Detail |
---|
public static final String OUTPUT_FILTER
public static final String COMPLETION_POLL_INTERVAL_KEY
public static final String PROGRESS_MONITOR_POLL_INTERVAL_KEY
public static final String USED_GENERIC_PARSER
public static final String SUBMIT_REPLICATION
Constructor Detail |
---|
@Deprecated public Job() throws IOException
IOException
@Deprecated public Job(org.apache.hadoop.conf.Configuration conf) throws IOException
IOException
@Deprecated public Job(org.apache.hadoop.conf.Configuration conf, String jobName) throws IOException
IOException
Method Detail |
---|
public static Job getInstance() throws IOException
Job
with no particular Cluster
.
A Cluster will be created with a generic Configuration
.
Job
, with no connection to a cluster yet.
IOException
public static Job getInstance(org.apache.hadoop.conf.Configuration conf) throws IOException
Job
with no particular Cluster
and a
given Configuration
.
The Job
makes a copy of the Configuration
so
that any necessary internal modifications do not reflect on the incoming
parameter.
A Cluster will be created from the conf parameter only when it's needed.
conf
- the configuration
Job
, with no connection to a cluster yet.
IOException
public static Job getInstance(org.apache.hadoop.conf.Configuration conf, String jobName) throws IOException
Job
with no particular Cluster
and a given jobName.
A Cluster will be created from the conf parameter only when it's needed.
The Job
makes a copy of the Configuration
so
that any necessary internal modifications do not reflect on the incoming
parameter.
conf
- the configuration
Job
, with no connection to a cluster yet.
IOException
public static Job getInstance(JobStatus status, org.apache.hadoop.conf.Configuration conf) throws IOException
Job
with no particular Cluster
and given
Configuration
and JobStatus
.
A Cluster will be created from the conf parameter only when it's needed.
The Job
makes a copy of the Configuration
so
that any necessary internal modifications do not reflect on the incoming
parameter.
status
- job statusconf
- job configuration
Job
, with no connection to a cluster yet.
IOException
@Deprecated public static Job getInstance(Cluster ignored) throws IOException
getInstance()
Job
with no particular Cluster
.
A Cluster will be created from the conf parameter only when it's needed.
The Job
makes a copy of the Configuration
so
that any necessary internal modifications do not reflect on the incoming
parameter.
ignored
-
Job
, with no connection to a cluster yet.
IOException
@Deprecated public static Job getInstance(Cluster ignored, org.apache.hadoop.conf.Configuration conf) throws IOException
getInstance(Configuration)
Job
with no particular Cluster
and given
Configuration
.
A Cluster will be created from the conf parameter only when it's needed.
The Job
makes a copy of the Configuration
so
that any necessary internal modifications do not reflect on the incoming
parameter.
ignored
- conf
- job configuration
Job
, with no connection to a cluster yet.
IOException
@InterfaceAudience.Private public static Job getInstance(Cluster cluster, JobStatus status, org.apache.hadoop.conf.Configuration conf) throws IOException
Job
with no particular Cluster
and given
Configuration
and JobStatus
.
A Cluster will be created from the conf parameter only when it's needed.
The Job
makes a copy of the Configuration
so
that any necessary internal modifications do not reflect on the incoming
parameter.
cluster
- clusterstatus
- job statusconf
- job configuration
Job
, with no connection to a cluster yet.
IOException
public JobStatus getStatus() throws IOException, InterruptedException
IOException
InterruptedException
public JobStatus.State getJobState() throws IOException, InterruptedException
IOException
InterruptedException
public String getTrackingURL()
public String getJobFile()
public long getStartTime()
public long getFinishTime() throws IOException, InterruptedException
IOException
InterruptedException
public String getSchedulingInfo()
public JobPriority getPriority() throws IOException, InterruptedException
IOException
InterruptedException
public String getJobName()
getJobName
in interface JobContext
getJobName
in class JobContextImpl
public String getHistoryUrl() throws IOException, InterruptedException
IOException
InterruptedException
public boolean isRetired() throws IOException, InterruptedException
IOException
InterruptedException
@InterfaceAudience.Private public Cluster getCluster()
public String toString()
toString
in class Object
public TaskReport[] getTaskReports(TaskType type) throws IOException, InterruptedException
type
- Type of the task
IOException
InterruptedException
public float mapProgress() throws IOException, InterruptedException
IOException
InterruptedException
public float reduceProgress() throws IOException, InterruptedException
IOException
InterruptedException
public float cleanupProgress() throws IOException, InterruptedException
IOException
InterruptedException
public float setupProgress() throws IOException, InterruptedException
IOException
InterruptedException
public boolean isComplete() throws IOException, InterruptedException
true
if the job is complete, else false
.
IOException
InterruptedException
public boolean isSuccessful() throws IOException, InterruptedException
true
if the job succeeded, else false
.
IOException
InterruptedException
public void killJob() throws IOException, InterruptedException
IOException
InterruptedException
public void setPriority(JobPriority priority) throws IOException, InterruptedException
priority
- the new priority for the job.
IOException
InterruptedException
public TaskCompletionEvent[] getTaskCompletionEvents(int startFrom, int numEvents) throws IOException, InterruptedException
startFrom
- index to start fetching events fromnumEvents
- number of events to fetch
TaskCompletionEvent
s
IOException
InterruptedException
public boolean killTask(TaskAttemptID taskId) throws IOException, InterruptedException
taskId
- the id of the task to be terminated.
IOException
InterruptedException
public boolean failTask(TaskAttemptID taskId) throws IOException, InterruptedException
taskId
- the id of the task to be terminated.
IOException
InterruptedException
public Counters getCounters() throws IOException, InterruptedException
IOException
InterruptedException
public String[] getTaskDiagnostics(TaskAttemptID taskid) throws IOException, InterruptedException
taskid
-
IOException
InterruptedException
public void setNumReduceTasks(int tasks) throws IllegalStateException
tasks
- the number of reduce tasks
IllegalStateException
- if the job is submittedpublic void setWorkingDirectory(org.apache.hadoop.fs.Path dir) throws IOException
dir
- the new current working directory.
IllegalStateException
- if the job is submitted
IOException
public void setInputFormatClass(Class<? extends InputFormat> cls) throws IllegalStateException
InputFormat
for the job.
cls
- the InputFormat
to use
IllegalStateException
- if the job is submittedpublic void setOutputFormatClass(Class<? extends OutputFormat> cls) throws IllegalStateException
OutputFormat
for the job.
cls
- the OutputFormat
to use
IllegalStateException
- if the job is submittedpublic void setMapperClass(Class<? extends Mapper> cls) throws IllegalStateException
Mapper
for the job.
cls
- the Mapper
to use
IllegalStateException
- if the job is submittedpublic void setJarByClass(Class<?> cls)
cls
- the example classpublic void setJar(String jar)
public void setUser(String user)
user
- the username for this job.public void setCombinerClass(Class<? extends Reducer> cls) throws IllegalStateException
cls
- the combiner to use
IllegalStateException
- if the job is submittedpublic void setReducerClass(Class<? extends Reducer> cls) throws IllegalStateException
Reducer
for the job.
cls
- the Reducer
to use
IllegalStateException
- if the job is submittedpublic void setPartitionerClass(Class<? extends Partitioner> cls) throws IllegalStateException
Partitioner
for the job.
cls
- the Partitioner
to use
IllegalStateException
- if the job is submittedpublic void setMapOutputKeyClass(Class<?> theClass) throws IllegalStateException
theClass
- the map output key class.
IllegalStateException
- if the job is submittedpublic void setMapOutputValueClass(Class<?> theClass) throws IllegalStateException
theClass
- the map output value class.
IllegalStateException
- if the job is submittedpublic void setOutputKeyClass(Class<?> theClass) throws IllegalStateException
theClass
- the key class for the job output data.
IllegalStateException
- if the job is submittedpublic void setOutputValueClass(Class<?> theClass) throws IllegalStateException
theClass
- the value class for job outputs.
IllegalStateException
- if the job is submittedpublic void setSortComparatorClass(Class<? extends org.apache.hadoop.io.RawComparator> cls) throws IllegalStateException
Reducer
.
cls
- the raw comparator
IllegalStateException
- if the job is submittedpublic void setGroupingComparatorClass(Class<? extends org.apache.hadoop.io.RawComparator> cls) throws IllegalStateException
Reducer.reduce(Object, Iterable,
org.apache.hadoop.mapreduce.Reducer.Context)
cls
- the raw comparator to use
IllegalStateException
- if the job is submittedpublic void setJobName(String name) throws IllegalStateException
name
- the job's new name.
IllegalStateException
- if the job is submittedpublic void setSpeculativeExecution(boolean speculativeExecution)
speculativeExecution
- true
if speculative execution
should be turned on, else false
.public void setMapSpeculativeExecution(boolean speculativeExecution)
speculativeExecution
- true
if speculative execution
should be turned on for map tasks,
else false
.public void setReduceSpeculativeExecution(boolean speculativeExecution)
speculativeExecution
- true
if speculative execution
should be turned on for reduce tasks,
else false
.public void setJobSetupCleanupNeeded(boolean needed)
needed
- If true
, job-setup and job-cleanup will be
considered from OutputCommitter
else ignored.public void setCacheArchives(URI[] archives)
archives
- The list of archives that need to be localizedpublic void setCacheFiles(URI[] files)
files
- The list of files that need to be localizedpublic void addCacheArchive(URI uri)
uri
- The uri of the cache to be localizedpublic void addCacheFile(URI uri)
uri
- The uri of the cache to be localizedpublic void addFileToClassPath(org.apache.hadoop.fs.Path file) throws IOException
addArchiveToClassPath(Path)
method instead.
file
- Path of the file to be added
IOException
public void addArchiveToClassPath(org.apache.hadoop.fs.Path archive) throws IOException
archive
- Path of the archive to be added
IOException
@Deprecated public void createSymlink()
public void setMaxMapAttempts(int n)
n
- the number of attempts per map task.public void setMaxReduceAttempts(int n)
n
- the number of attempts per reduce task.public void setProfileEnabled(boolean newValue)
newValue
- true means it should be gatheredpublic void setProfileParams(String value)
value
- the configuration stringpublic void setProfileTaskRange(boolean isMap, String newValue)
newValue
- a set of integer ranges of the map idspublic void setCancelDelegationTokenUponJobCompletion(boolean value)
@InterfaceAudience.Private public org.apache.hadoop.mapreduce.JobSubmitter getJobSubmitter(org.apache.hadoop.fs.FileSystem fs, ClientProtocol submitClient) throws IOException
IOException
public void submit() throws IOException, InterruptedException, ClassNotFoundException
IOException
InterruptedException
ClassNotFoundException
public boolean waitForCompletion(boolean verbose) throws IOException, InterruptedException, ClassNotFoundException
verbose
- print the progress to the user
IOException
- thrown if the communication with the
JobTracker
is lost
InterruptedException
ClassNotFoundException
public boolean monitorAndPrintJob() throws IOException, InterruptedException
IOException
- if communication to the JobTracker fails
InterruptedException
public static int getProgressPollInterval(org.apache.hadoop.conf.Configuration conf)
public static int getCompletionPollInterval(org.apache.hadoop.conf.Configuration conf)
public static Job.TaskStatusFilter getTaskOutputFilter(org.apache.hadoop.conf.Configuration conf)
conf
- the configuration.
public static void setTaskOutputFilter(org.apache.hadoop.conf.Configuration conf, Job.TaskStatusFilter newValue)
conf
- the Configuration to modify.newValue
- the value to set.public boolean isUber() throws IOException, InterruptedException
IOException
InterruptedException
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |