@InterfaceAudience.Public @InterfaceStability.Stable public abstract class CombineFileInputFormat<K,V> extends CombineFileInputFormat<K,V> implements InputFormat<K,V>
InputFormat that returns CombineFileSplit's
 in InputFormat.getSplits(JobConf, int) method. 
 Splits are constructed from the files under the input paths. 
 A split cannot have files from different pools.
 Each split returned may contain blocks from different files.
 If a maxSplitSize is specified, then blocks on the same node are
 combined to form a single split. Blocks that are left over are
 then combined with other blocks in the same rack. 
 If maxSplitSize is not specified, then blocks from the same rack
 are combined in a single split; no attempt is made to create
 node-local splits.
 If the maxSplitSize is equal to the block size, then this class
 is similar to the default spliting behaviour in Hadoop: each
 block is a locally processed split.
 Subclasses implement InputFormat.getRecordReader(InputSplit, JobConf, Reporter)
 to construct RecordReader's for CombineFileSplit's.CombineFileSplitSPLIT_MINSIZE_PERNODE, SPLIT_MINSIZE_PERRACKDEFAULT_LIST_STATUS_NUM_THREADS, INPUT_DIR, INPUT_DIR_RECURSIVE, LIST_STATUS_NUM_THREADS, NUM_INPUT_FILES, PATHFILTER_CLASS, SPLIT_MAXSIZE, SPLIT_MINSIZE| Constructor and Description | 
|---|
| CombineFileInputFormat()default constructor | 
| Modifier and Type | Method and Description | 
|---|---|
| protected void | createPool(JobConf conf,
          List<PathFilter> filters)Deprecated. 
 | 
| protected void | createPool(JobConf conf,
          PathFilter... filters)Deprecated. 
 | 
| RecordReader<K,V> | createRecordReader(InputSplit split,
                  TaskAttemptContext context)This is not implemented yet. | 
| abstract RecordReader<K,V> | getRecordReader(InputSplit split,
               JobConf job,
               Reporter reporter)This is not implemented yet. | 
| InputSplit[] | getSplits(JobConf job,
         int numSplits)Logically split the set of input files for the job. | 
| protected boolean | isSplitable(FileSystem fs,
           Path file) | 
| protected FileStatus[] | listStatus(JobConf job)List input directories. | 
createPool, createPool, getFileBlockLocations, getSplits, isSplitable, setMaxSplitSize, setMinSplitSizeNode, setMinSplitSizeRackaddInputPath, addInputPathRecursively, addInputPaths, computeSplitSize, getBlockIndex, getFormatMinSplitSize, getInputDirRecursive, getInputPathFilter, getInputPaths, getMaxSplitSize, getMinSplitSize, listStatus, makeSplit, makeSplit, setInputDirRecursive, setInputPathFilter, setInputPaths, setInputPaths, setMaxInputSplitSize, setMinInputSplitSizepublic InputSplit[] getSplits(JobConf job, int numSplits) throws IOException
InputFormatEach InputSplit is then assigned to an individual Mapper
 for processing.
Note: The split is a logical split of the inputs and the input files are not physically split into chunks. For e.g. a split could be <input-file-path, start, offset> tuple.
getSplits in interface InputFormat<K,V>job - job configuration.numSplits - the desired number of splits, a hint.InputSplits for the job.IOException@Deprecated protected void createPool(JobConf conf, List<PathFilter> filters)
CombineFileInputFormat.createPool(List).@Deprecated protected void createPool(JobConf conf, PathFilter... filters)
CombineFileInputFormat.createPool(PathFilter...).public abstract RecordReader<K,V> getRecordReader(InputSplit split, JobConf job, Reporter reporter) throws IOException
getRecordReader in interface InputFormat<K,V>split - the InputSplitjob - the job that this split belongs toRecordReaderIOExceptionpublic RecordReader<K,V> createRecordReader(InputSplit split, TaskAttemptContext context) throws IOException
CombineFileInputFormatcreateRecordReader in class CombineFileInputFormat<K,V>split - the split to be readcontext - the information about the taskIOExceptionprotected FileStatus[] listStatus(JobConf job) throws IOException
job - the job to list input paths forIOException - if zero items.protected boolean isSplitable(FileSystem fs, Path file)
Copyright © 2022 Apache Software Foundation. All rights reserved.