温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Java的Hadoop KeyValueTextInputFormat怎么使用

发布时间:2021-12-09 14:24:50 阅读:174 作者:iii 栏目:大数据
Java开发者专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

这篇文章主要讲解了“Java的Hadoop KeyValueTextInputFormat怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java的Hadoop KeyValueTextInputFormat怎么使用”吧!

KeyValueTextInputFormat使用案例

1.需求

统计输入文件中每一行的第一个单词相同的行数。

(1)  输入数据

hadoop ni haoxiaoming hive helloworldhadoop ni haoxiaoming hive helloworld

(2)  期望结果数据

hadoop  2xiaoming  2

2.需求分析

Java的Hadoop KeyValueTextInputFormat怎么使用

3.代码编写 

(1)  编写Mapper类

public class KVTextMapper extends Mapper<Text, Text, Text, LongWritable>{// 1 设置value   LongWritable v = new LongWritable(1);  @Override  protected void map(Text key, Text value, Context context)      throws IOExceptionInterruptedException {        // 2 写出        context.write(key, v);    }}

(2)  编写Reducer类

public class KVTextReducer extends Reducer<Text, LongWritable, Text, LongWritable>{    LongWritable v = new LongWritable();  @Override  protected void reduce(Text key, Iterable<LongWritable> values,  Context context) throws IOException, InterruptedException {     long sum = 0L;     // 1 汇总统计        for (LongWritable value : values) {              sum += value.get();          }             v.set(sum);          // 2 输出        context.write(key, v);    }}

(3)  编写Driver类

public class KVTextDriver {  public static void main(String[] args) throws IOException, ClassNotFoundException, InterruptedException {    Configuration conf = new Configuration();    // 设置切割符  conf.set(KeyValueLineRecordReader.KEY_VALUE_SEPERATOR, " ");    // 1 获取job对象    Job job = Job.getInstance(conf);    // 2 设置jar包位置,关联mapper和reducer    job.setJarByClass(KVTextDriver.class);    job.setMapperClass(KVTextMapper.class);job.setReducerClass(KVTextReducer.class);    // 3 设置map输出kv类型    job.setMapOutputKeyClass(Text.class);    job.setMapOutputValueClass(LongWritable.class);    // 4 设置最终输出kv类型    job.setOutputKeyClass(Text.class);job.setOutputValueClass(LongWritable.class);    // 5 设置输入输出数据路径    FileInputFormat.setInputPaths(job, new Path(args[0]));    // 设置输入格式  job.setInputFormatClass(KeyValueTextInputFormat.class);    // 6 设置输出数据路径    FileOutputFormat.setOutputPath(job, new Path(args[1]));    // 7 提交job    job.waitForCompletion(true);  }}

感谢各位的阅读,以上就是“Java的Hadoop KeyValueTextInputFormat怎么使用”的内容了,经过本文的学习后,相信大家对Java的Hadoop KeyValueTextInputFormat怎么使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

原文链接:https://my.oschina.net/u/4631338/blog/4533506

AI

开发者交流群×