MapReduce模板程序

来源:互联网 发布:好句子 知乎 编辑:程序博客网 时间:2024/05/16 20:27
该程序功能:将如下数据
13599999999 10086
13899999999120
13944444444 13800138000
13722222222 13800138000
18800000000 120
13722222222 10086
18944444444 10086
处理为类似:10086    13599999999|13722222222|18944444444  
 


/**  
 * Hadoop模板程序
 */  

import java.io.IOException;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;


import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.conf.Configured;
import org.apache.hadoop.fs.Path;
import org.apache.hadoop.io.*;
import org.apache.hadoop.mapreduce.*;
import org.apache.hadoop.mapreduce.lib.input.FileInputFormat;
import org.apache.hadoop.mapreduce.lib.output.FileOutputFormat;
import org.apache.hadoop.mapreduce.lib.output.TextOutputFormat;
import org.apache.hadoop.util.Tool;
import org.apache.hadoop.util.ToolRunner;
 
/**  
 * 有Reducer版本
 */  
public class Test_2 extends Configured implements Tool {
/**  
* 计数器
* 用于计数各种异常数据
*/  
enum Counter 
{
LINESKIP,//出错的行
}
/**  
* MAP任务
*/  
public static class Map extends Mapper<LongWritable, Text, Text, Text> 
{
public void map ( LongWritable key, Text value, Context context ) throws IOException, InterruptedException 
{
String line = value.toString();//读取源数据
try
{
//数据处理
String [] lineSplit = line.split(" ");
String anum = lineSplit[0];
String bnum = lineSplit[1];
context.write( new Text(bnum), new Text(anum) );//输出,key和value之间会自动加上\t制表符,如果不希望的话可以将key设置为NullWritable类型,修改key类型后相应多处设置输出类型的参数都要修改,此处为NullWritable.get()
}
catch ( java.lang.ArrayIndexOutOfBoundsException e )
{
context.getCounter(Counter.LINESKIP).increment(1);//出错令计数器+1
return;
}
}
}

/**  
* REDUCE任务
*/ 
public static class Reduce extends Reducer<Text, Text, Text, Text> 
{
public void reduce ( Text key, Iterable<Text> values, Context context ) throws IOException, InterruptedException
{
String valueString;
String out = "";
for ( Text value : values )
{
valueString = value.toString();
out += valueString + "|";
}
context.write( key, new Text(out) );
}
}

@Override
public int run(String[] args) throws Exception 
{
Configuration conf = getConf();

Job job = new Job(conf, "Test_2");//任务名
job.setJarByClass(Test_2.class);//指定Class
FileInputFormat.addInputPath( job, new Path(args[0]) );//输入路径
FileOutputFormat.setOutputPath( job, new Path(args[1]) );//输出路径
job.setMapperClass( Map.class );//调用上面Map类作为Map任务代码
job.setReducerClass ( Reduce.class );//调用上面Reduce类作为Reduce任务代码
job.setOutputFormatClass( TextOutputFormat.class );
job.setOutputKeyClass( Text.class );//指定输出的KEY的格式
job.setOutputValueClass( Text.class );//指定输出的VALUE的格式
job.waitForCompletion(true);
//输出任务完成情况
System.out.println( "任务名称:" + job.getJobName() );
System.out.println( "任务成功:" + ( job.isSuccessful()?"是":"否" ) );
System.out.println( "输入行数:" + job.getCounters().findCounter("org.apache.hadoop.mapred.Task$Counter", "MAP_INPUT_RECORDS").getValue() );
System.out.println( "输出行数:" + job.getCounters().findCounter("org.apache.hadoop.mapred.Task$Counter", "MAP_OUTPUT_RECORDS").getValue() );
System.out.println( "跳过的行:" + job.getCounters().findCounter(Counter.LINESKIP).getValue() );

return job.isSuccessful() ? 0 : 1;
}
/**  
* 设置系统说明
* 设置MapReduce任务
*/  
public static void main(String[] args) throws Exception 
{
//判断参数个数是否正确
//如果无参数运行则显示以作程序说明
if ( args.length != 2 )
{
System.err.println("");
System.err.println("Usage: Test_2 < input path > < output path > ");
System.err.println("Example: hadoop jar ~/Test_2.jar hdfs://localhost:9000/home/james/Test_2 hdfs://localhost:9000/home/james/output");
System.err.println("Counter:");
System.err.println("\t"+"LINESKIP"+"\t"+"Lines which are too short");
System.exit(-1);
}
//记录开始时间
DateFormat formatter = new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss" );
Date start = new Date();
//运行任务
int res = ToolRunner.run(new Configuration(), new Test_2(), args);

//输出任务耗时
Date end = new Date();
float time =  (float) (( end.getTime() - start.getTime() ) / 60000.0) ;
System.out.println( "任务开始:" + formatter.format(start) );
System.out.println( "任务结束:" + formatter.format(end) );
System.out.println( "任务耗时:" + String.valueOf( time ) + " 分钟" ); 

        System.exit(res);
}
}
原创粉丝点击