Java tutorial
/* * Credit: This file includes code derived from the Apache Software Foundation's * Hadoop project (http://hadoop.apache.org/) and released under the Apache * License, Version 2.0. * * Copyright (C) 2017 Republic Wireless * * 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 com.rw.legion.input; import com.google.common.base.Charsets; import com.rw.legion.LegionRecord; import org.apache.hadoop.classification.InterfaceAudience; import org.apache.hadoop.classification.InterfaceStability; import org.apache.hadoop.fs.Path; import org.apache.hadoop.io.NullWritable; import org.apache.hadoop.mapreduce.InputSplit; import org.apache.hadoop.mapreduce.JobContext; import org.apache.hadoop.mapreduce.RecordReader; import org.apache.hadoop.mapreduce.TaskAttemptContext; import org.apache.hadoop.mapreduce.lib.input.FileInputFormat; /** * An <code>InputFormat</code> for <code>CsvRecordReader</code>. Essentially, * the default Hadoop <code>TextInputFormat</code> modified to use the * <code>CsvRecordReader</code>. */ @InterfaceAudience.Public @InterfaceStability.Stable public class CsvInputFormat extends FileInputFormat<NullWritable, LegionRecord> { @Override public RecordReader<NullWritable, LegionRecord> createRecordReader(InputSplit split, TaskAttemptContext context) { String delimiter = context.getConfiguration().get("textinputformat.record.delimiter"); byte[] recordDelimiterBytes = null; if (null != delimiter) recordDelimiterBytes = delimiter.getBytes(Charsets.UTF_8); return new CsvRecordReader(recordDelimiterBytes); } @Override protected boolean isSplitable(JobContext context, Path file) { /* * Legion doesn't currently support splitting CSVs, because the header * would only be in the first split. A fix can be investigated for a * future release, though. */ return false; } }