美文网首页
MapReduce实验--计数器

MapReduce实验--计数器

作者: 快点学 | 来源:发表于2019-12-02 18:09 被阅读0次

    一、Mapreduce计数器

    用来记录job执行的进度和状态, 可以理解为日志, 通过在程序某个位置插入计数器来记录数据或者进度的变化情况。

    package Mapreduce_Counters;
    
    import java.io.IOException;
    
    import org.apache.hadoop.conf.Configuration;
    import org.apache.hadoop.fs.Path;
    import org.apache.hadoop.io.LongWritable;
    import org.apache.hadoop.io.Text;
    import org.apache.hadoop.mapreduce.Counter;
    import org.apache.hadoop.mapreduce.Job;
    import org.apache.hadoop.mapreduce.Mapper;
    import org.apache.hadoop.mapreduce.lib.input.FileInputFormat;
    import org.apache.hadoop.mapreduce.lib.output.FileOutputFormat;
    import org.apache.hadoop.util.GenericOptionsParser;
    
    public class Counters {
        
        public static class MyCounterMap extends Mapper<LongWritable, Text, Text, Text> {
            public static Counter ct = null;
            protected void map(LongWritable key, Text value, Context context) throws IOException, InterruptedException {
                String arr_valueString[] = value.toString().split("\t");
                if (arr_valueString.length > 3) {
                    ct = context.getCounter("ErrorCounter", "toolong"); // ErrorCounter为组名,toolong为组员名
                    ct.increment(1);
                } else if (arr_valueString.length < 3) {
                    ct = context.getCounter("ErrorCounter", "tooshort");
                    ct.increment(1);
                }
            }
        }
    
        public static void main(String[] args) throws IOException, ClassNotFoundException, InterruptedException {
            Configuration conf = new Configuration();
            String[] otherArgs = new GenericOptionsParser(conf, args).getRemainingArgs();
            if (otherArgs.length != 2) {
                System.out.println("Usage: Counters<in><out>");
                System.exit(2);
            }
            
            Job job = new Job(conf, "MyJob");
            job.setJarByClass(Counters.class);
            job.setMapperClass(MyCounterMap.class);
            
            FileInputFormat.addInputPath(job, new Path(otherArgs[0]));
            FileOutputFormat.setOutputPath(job, new Path(otherArgs[1]));
            System.exit(job.waitForCompletion(true)?0:1);
        }
    }
    

    相关文章

      网友评论

          本文标题:MapReduce实验--计数器

          本文链接:https://www.haomeiwen.com/subject/zdufgctx.html