2019独角兽企业重金招聘Python工程师标准>>>

环境为Hadoop2.5.2(如何搭建环境教程),在pom.xml中加入以下配置文件。

<dependency><groupId>org.apache.hadoop</groupId><artifactId>hadoop-common</artifactId><version>2.5.2</version>
</dependency>
<dependency><groupId>org.apache.hadoop</groupId><artifactId>hadoop-hdfs</artifactId><version>2.5.2</version>
</dependency><dependency><groupId>org.apache.hadoop</groupId><artifactId>hadoop-client</artifactId><version>2.5.2</version>
</dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>3.8.1</version><scope>test</scope>
</dependency>

测试HDFS

public class HdfsTest
{public static void main( String[] args ) throws IOException {String uri = "hdfs://192.168.1.112:9000/";Configuration config = new Configuration();FileSystem fs = FileSystem.get(URI.create(uri), config);//列出目录所有文件FileStatus[] statuses = fs.listStatus(new Path("/data"));for (FileStatus status : statuses) {System.out.println(status);}//创建新文件FSDataOutputStream os = fs.create(new Path("/data/hdfs_test.txt"));os.write("测试HDFS第一条\r\n".getBytes());os.write("测试HDFS第二条\r\n".getBytes());os.flush();os.close();//读取文件InputStream is = fs.open(new Path("/data/hdfs_test.txt"));IOUtils.copyBytes(is, System.out, 1024, true);}
}

测试Map/Reduce

实例:将多个文件里面的内容去掉重复行。

思路:把数据行当做map/reduce的key来处理即可。value可以为空。

代码实现如下:

package com.zhm;import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.Path;
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;import java.io.IOException;/*** Created by zhm on 2015/7/8.*/
public class MapReduceTest {public static class MyMapper extends Mapper<Object, Text, Text, Text> {public void map(Object key, Text value, Context context) throws IOException, InterruptedException {//将文本行放入keycontext.write(value,new Text(""));}}public static class MyReducer extends Reducer<Text,Text,Text,Text> {public void reduce(Text key, Iterable<Text> values, Context context) throws IOException, InterruptedException {//输出keycontext.write(key, new Text(""));}}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: MapReduceTest <in> <out>");System.exit(2);}Job job = Job.getInstance(conf, "MapReduceTest");job.setJarByClass(MapReduceTest.class);job.setMapperClass(MyMapper.class);job.setCombinerClass(MyReducer.class);job.setReducerClass(MyReducer.class);job.setOutputKeyClass(Text.class);job.setOutputValueClass(Text.class);FileInputFormat.addInputPath(job, new Path(otherArgs[0]));FileOutputFormat.setOutputPath(job, new Path(otherArgs[1]));System.exit(job.waitForCompletion(true) ? 0 : 1);}
}

运行:mvn clean package 打好jar包。并上传至服务器的hadoop安装目录中。

在服务器上创建需要统计去重的文件。

mkdir /tmp/mapredcd /tmp/mapred
vi file1.txt
#输入以下内容
192.168.1.1
192.168.1.2
192.168.1.4vi file2.txt
#输入以下内容
192.168.1.3
192.168.1.2
192.168.1.5vi file3.txt
#输入以下内容
192.168.1.1
192.168.1.3
192.168.1.4#清空hdfs目录,tmp目录不要删除。主要是测试方便,也可以不删除目录,只要将文件指定一个新的测试目录就行。
hdfs dfs -rm -r -f -skipTrash /目录名#将创建好的文件上传至HDFShdfs dfs -put /tmp/mapred /input#进入hadoop安装主目录
hadoop jar maven_hadoop-1.0-SNAPSHOT.jar com.zhm.MapReduceTest /input /output#查看结果
hdfs dfs -cat /output/part-r-00000
#结果如下:
192.168.1.1
192.168.1.2
192.168.1.3
192.168.1.4
192.168.1.5

转载于:https://my.oschina.net/zhmlvft/blog/475950

使用Maven开发Hadoop相关推荐

  1. 用Maven构建Hadoop项目

    Hadoop家族系列文章,主要介绍Hadoop家族产品,常用的项目包括Hadoop, Hive, Pig, HBase, Sqoop, Mahout, Zookeeper, Avro, Ambari, ...

  2. 转】用Maven构建Hadoop项目

    原博文出自于: http://blog.fens.me/hadoop-maven-eclipse/ 感谢! 用Maven构建Hadoop项目 Hadoop家族系列文章,主要介绍Hadoop家族产品,常 ...

  3. Spark Idea Maven 开发环境搭建(转载)

    mark一下,感谢作者分享! Spark Idea Maven 开发环境搭建 一.安装jdk jdk版本最好是1.7以上,设置好环境变量,安装过程,略. 二.安装Maven 我选择的Maven版本是3 ...

  4. eclipse搭建maven开发环境

    eclipse搭建maven开发环境 eclipse搭建maven开发环境 maven作为一个项目构建工具,在开发的过程中很受欢迎,可以帮助管理项目中的bao依赖问题,另外它的很多功能都极大的减少了开 ...

  5. 使用Maven开发用户模块的CRUD(增删改查)

    使用Maven开发用户模块的CRUD(增删改查) < 使用Maven开发Web应用Archiva服务器的搭建步骤 > C语言中文网推出辅导班啦,包括「C语言辅导班.C++辅导班.算法/数据 ...

  6. SpringMVC+Maven开发项目源码详细介绍

    代码地址如下: http://www.demodashi.com/demo/11638.html Spring MVC概述 Spring MVC框架是一个开源的Java平台,为开发强大的基于Java的 ...

  7. Maven开发环境设置导致的异常java.lang.NumberFormatException: null

    Maven开发环境设置导致的异常java.lang.NumberFormatException: null 参考文章: (1)Maven开发环境设置导致的异常java.lang.NumberForma ...

  8. JDK11+Maven开发JavaFx启动问题:java.lang.IllegalAccessError: class com.sun.javafx.fxml.FXMLLoaderHelper

    JDK11 + Maven 开发 JavaFx 创建 Maven 项目 引入依赖 尝试启动(失败) 遇到问题 解决方案 旧电脑上 JDK8 开发 JavaFx 项目就很舒服欸,JDK11 不内置 Ja ...

  9. 《Maven官方文档》Maven 开发

    译者|carvendy 编辑|包包 Maven 开发  这文档描述怎么入门开发Maven.这是一个独立页来描述怎么构建Maven的. 找一些工作来做 首先你需要一些事情来做!解决方案可以在几个JIRA ...

最新文章

  1. mysql迅速搭建网页_Django + mysql 快速搭建简单web投票系统
  2. 科学家用计算机模拟后确认 60个n原子,科学家用计算机模拟后确认,60个N原子可结合成N60分子。下列关于N60的叙述中正确的是A.N60是一种新型的化合物...
  3. Python 可以满足你任何 API 使用需求
  4. Extjs window组件 拖动统制
  5. Java第四周编程总结
  6. 《电子基础与维修工具核心教程》——第2章 电阻2.1 电阻器介绍
  7. 网络学习(一)网络版块主题介绍
  8. 基于R语言绘制BBC风格图表
  9. 垃圾收集器分类与GC性能指标
  10. x86系统引导(1)
  11. 创新思维案列分析——苹果公司
  12. 495. Teemo Attacking(提莫攻击)
  13. CSS-盒子模型,标准盒子模型,IE 盒子模型,盒模型之间的转换
  14. aspcms系统加密后https后台无法登录解决办法
  15. SSH 登录指纹验证
  16. win10网络适配器不见了_win10设备管理器里没有网络适配器的原因及处理方法
  17. 安卓简易音乐播放器实现
  18. 《红警2》防空步兵都说了些什么?
  19. waiting for changelog lock.
  20. mysql 进阶(二)

热门文章

  1. 马斯克又有新麻烦上身!前员工将他告到美国证监会,曝出一大堆惊天八卦
  2. 碰撞与鲜血:人类与自动驾驶的坎坷摩擦
  3. 苹果自动驾驶测试车近距离实拍,头顶新添传感器和硬件
  4. 用 :focus-within 实现纯 CSS 下拉框组件
  5. MyBatis SQL注入隐患及防范
  6. 使用开源库 Objective-C RegEx Categories 处理正则表达式
  7. 子组件调用父组件方法
  8. ASP.NET Core 2.1 : 十.升级现有Core2.0 项目到2.1
  9. ROS机器人程序设计(原书第2版)3.1.2 ROS节点启动时调用gdb调试器
  10. 《Ruby程序员修炼之道》(第2版)—第1章1.1节进入Ruby的世界