Linux下MapReduce编程WordCount练习——使用命令行编译打包运行MapReduce程序(里面有对应安装包下载)

一、WordCount练习

要在 Eclipse 上编译和运行 MapReduce 程序,需要安装 hadoop-eclipse-plugin,参见厦大网址。
hadoop2x-eclipse-plugin-master的安装包
提取码:6l8p
(我把这次实验需要用到的hadoop2x-eclipse-plugin-master的安装包放在了我的百度网盘,需要的可以点击上面链接直接下载,下载完成后放进ubuntu相应目录里面压缩即可使用)
1、查看 HDFS 中的文件列表
在这里插入图片描述
2、在 Eclipse 中创建 MapReduce 项目WordCount
在这里插入图片描述
3、新建类 Class,在 Package 处填写 org.apache.hadoop.examples;在 Name 处填写 WordCount,如图
在这里插入图片描述
4、 WordCount.java 这个文件的代码如下

    package org.apache.hadoop.examples;
     
    import java.io.IOException;
    import java.util.Iterator;
    import java.util.StringTokenizer;
    import org.apache.hadoop.conf.Configuration;
    import org.apache.hadoop.fs.Path;
    import org.apache.hadoop.io.IntWritable;
    import org.apache.hadoop.io.Text;
    import org.apache.hadoop.mapreduce.Job;
    import org.apache.hadoop.mapreduce.Mapper;
    import org.apache.hadoop.mapreduce.Reducer;
    import org.apache.hadoop.mapreduce.lib.input.FileInputFormat;
    import org.apache.hadoop.mapreduce.lib.output.FileOutputFormat;
    import org.apache.hadoop.util.GenericOptionsParser;
     
    public class WordCount {
        public WordCount() {
        }
     
        public static void main(String[] args) throws Exception {
            Configuration conf = new Configuration();
            String[] otherArgs = (new GenericOptionsParser(conf, args)).getRemainingArgs();
            if(otherArgs.length < 2) {
                System.err.println("Usage: wordcount <in> [<in>...] <out>");
                System.exit(2);
            }
     
            Job job = Job.getInstance(conf, "word count");
            job.setJarByClass(WordCount.class);
            job.setMapperClass(WordCount.TokenizerMapper.class);
            job.setCombinerClass(WordCount.IntSumReducer.class);
            job.setReducerClass(WordCount.IntSumReducer.class);
            job.setOutputKeyClass(Text.class);
            job.setOutputValueClass(IntWritable.class);
     
            for(int i = 0; i < otherArgs.length - 1; ++i) {
                FileInputFormat.addInputPath(job, new Path(otherArgs[i]));
            }
     
            FileOutputFormat.setOutputPath(job, new Path(otherArgs[otherArgs.length - 1]));
            System.exit(job.waitForCompletion(true)?0:1);
        }
     
        public static class IntSumReducer extends Reducer<Text, IntWritable, Text, IntWritable> {
            private IntWritable result = new IntWritable();
     
            public IntSumReducer() {
            }
     
            public void reduce(Text key, Iterable<IntWritable> values, Reducer<Text, IntWritable, Text, IntWritable>.Context context) throws IOException, InterruptedException {
                int sum = 0;
     
                IntWritable val;
                for(Iterator i$ = values.iterator(); i$.hasNext(); sum += val.get()) {
                    val = (IntWritable)i$.next();
                }
     
                this.result.set(sum);
                context.write(key, this.result);
            }
        }
     
        public static class TokenizerMapper extends Mapper<Object, Text, Text, IntWritable> {
            private static final IntWritable one = new IntWritable(1);
            private Text word = new Text();
     
            public TokenizerMapper() {
            }
     
            public void map(Object key, Text value, Mapper<Object, Text, Text, IntWritable>.Context context) throws IOException, InterruptedException {
                StringTokenizer itr = new StringTokenizer(value.toString());
     
                while(itr.hasMoreTokens()) {
                    this.word.set(itr.nextToken());
                    context.write(this.word, one);
                }
     
            }
        }
    }

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
5、复制配置文件解决参数设置问题

    cp /usr/local/hadoop/etc/hadoop/core-site.xml ~/workspace/WordCount/src
    cp /usr/local/hadoop/etc/hadoop/hdfs-site.xml ~/workspace/WordCount/src
    cp /usr/local/hadoop/etc/hadoop/log4j.properties ~/workspace/WordCount/src

在这里插入图片描述
6、复制完成后,右键点击 WordCount 选择 refresh 进行刷新,可以看到文件结构如下所示
在这里插入图片描述
7、设置运行时的相关参数,如图所示
在这里插入图片描述
也可以直接在代码中设置好输入参数,如图所示
在这里插入图片描述
8、设定参数后,再次运行程序,可以看到运行成功的提示如下所示
在这里插入图片描述
9、做到这里,就可以使用 Eclipse 方便的进行 MapReduce程序的开发了

二、编译、打包 Hadoop MapReduce 程序

10、将 Hadoop 的 classhpath 信息添加到 CLASSPATH 变量,执行 source ~/.bashrc 使变量生效

vim  ~/.bashrc
source ~/.bashrc

在这里插入图片描述
11、通过 javac 命令编译 WordCount.java
(这里要到你的WordCount.java目录下运行!)

javac WordCount.java

在这里插入图片描述

12、把 .class 文件打包成 jar
(这里也在相关目录下运行)

jar -cvf WordCount.jar ./WordCount*.class

在这里插入图片描述
如图(生成的jar包)
在这里插入图片描述
(我把它拷贝到了workspace/WordCount目录下,方便!)
在这里插入图片描述
13、打包完成后,运行,创建几个输入文件

    mkdir input
    echo "echo of the rainbow" > ./input/file0
    echo "the waiting game" > ./input/file1

在这里插入图片描述
14、查看input下的文件

ls ./input

在这里插入图片描述
15、把本地文件上传到伪分布式HDFS上

/usr/local/hadoop/bin/hadoop fs -put ./input input

在这里插入图片描述

16、开始运行(代码中设置了package包名,这里要写全!)

/usr/local/hadoop/bin/hadoop jar WordCount.jar org/apache/hadoop/examples/WordCount input output

在这里插入图片描述
终端运行结果
在这里插入图片描述
17、Localhost:50070端口查看/user/hadoop/output/结果
在这里插入图片描述
终端查看伪分布式下/user/hadoop/output/结果

cd /usr/local/hadoop
./bin/hdfs dfs -ls /user/hadoop/output

在这里插入图片描述
18、查看伪分布式下/user/hadoop/output/part-r-00000结果

./bin/hdfs dfs -cat /user/hadoop/output/part-r-00000

在这里插入图片描述

三、遇见的问题及解决办法

问题一:出现找不到类的错误
在这里插入图片描述
解决办法:这是因为在代码中设置了package包名,这里也要写全(正确的命令:/usr/local/hadoop/bin/hadoop jar WordCount.jar org/apache/hadoop/examples/WordCount input output)
问题二:Exception in thread “main” org.apache.hadoop.mapred.FileAlreadyExistsException: Output directory hdfs://localhost:9000/user/hadoop/output already exists
在这里插入图片描述

解决办法:伪分布式下删除运行时自动创建的output

./bin/hdfs dfs -rm -r /user/hadoop/output

在这里插入图片描述
加油!
在这里插入图片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章