12.4 二

让类【DeduplicationMapper】继承类Mapper同时指定需要的参数类型,根据业务逻辑修改map类的内容如下。
package com.simple.duduplication;
import java.io.IOException;
import org.apache.hadoop.io.LongWritable;
import org.apache.hadoop.io.Text;
import org.apache.hadoop.mapreduce.Mapper;
public class DeduplicationMapper extends Mapper<LongWritable, Text, Text, Text> {
@Override
protected void map(LongWritable key, Text value, Mapper<LongWritable, Text, Text, Text>.Context context)
throws IOException, InterruptedException {
//按行读取信息并作为mapper的输出键,mapper的输出值置为空文本即可
Text line = value;
context.write(line, new Text(’’));
}
}

在项目src目录下指定的包名【com.simple.deduplication】下右键点击,新建一个类名为【DeduplicationReducer】并继承Reducer类,然后添加该类中的代码内容如下所示。
package com.simple.duduplication;
import java.io.IOException;
import org.apache.hadoop.io.Text;
import org.apache.hadoop.mapreduce.Reducer;
public class DeduplicationReducer extends Reducer<Text, Text, Text, Text> {
@Override
protected void reduce(Text key, Iterable value, Reducer<Text, Text, Text, Text>.Context context)
throws IOException, InterruptedException {
//Reducer阶段直接按键输出即可,键直接可以实现去重
context.write(key, new Text(’’));
}
}

在项目src目录下指定的包名【com.simple.deduplication】下右键点击,新建一个测试主类名为【TestDeduplication】并指定main主方法,测试代码如下所示:
package com.simple.duduplication;
import java.io.IOException;
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.lib.input.FileInputFormat;
import org.apache.hadoop.mapreduce.lib.output.FileOutputFormat;
public class TestDeduplication {
public static void main(String[] args) throws Exception {
Configuration conf = new Configuration();
conf.set(‘fs.defaultFS’, ‘hdfs://localhost:9000’);
//获取作业对象
Job job = Job.getInstance(conf);
//设置主类
job.setJarByClass(TestDeduplication.class);
//设置job参数
job.setMapperClass(DeduplicationMapper.class);
job.setReducerClass(DeduplicationReducer.class);
job.setOutputKeyClass(Text.class);
job.setOutputValueClass(Text.class);
//设置job输入输出
FileInputFormat.addInputPath(job, new Path(args[0]));
FileOutputFormat.setOutputPath(job, new Path(args[1]));
System.exit(job.waitForCompletion(true) ? 0 : 1);
}
}

按照以上的步骤,把mapper和reducer阶段以及测试代码编写完毕之后,选中测试类【TestDeduplication】,右键点击选择【Run as】->【Run Configurations】->【Java Application】->【TestDeduplication】->【Arguments】,在【Program arguments】中输入参数并且参数间用空格隔开,输入完毕后,点击【Run】运行.

Xcode 12.4是一款由Apple开发的集成开发环境(IDE),用于在Mac OS X操作系统上进行软件开发。它包含了iOS 14.4、iPadOS 14.4、tvOS 14.4、watchOS 7.2以及macOS Big Sur 11.1的SDK。Xcode 12.4支持iOS 9及以上版本、tvOS 9及以上版本、watchOS 2及以上版本,并需要在安装有macOS 10.15.4及以上版本的电脑上使用。 如果您的电脑是运行在Catalina 10.15.7上的,而App Store显示由于版本过低无法安装Xcode,您可以尝试从第三方网站下载Xcode 12.4的应用程序。一个相对安全的下载地址是https://cloud.mfpud.com/Application/Xcode/,您可以下载Xcode_12.4.xip文件并解压缩后安装。然后,您还需要下载Xcode 12.4的真机配置包,将其拖到已解压的Xcode 12.4应用程序中的指定位置。 请注意,从非官方和未经验证的第三方网站下载Xcode应用程序可能存在安全风险,因此建议您谨慎操作。 希望这些信息对您有所帮助。如果您还有其他问题,请随时提问。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [2021-07-09](https://blog.csdn.net/bjnbt/article/details/118610239)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Xcode12.4发布说明(翻译)](https://blog.csdn.net/guoyongming925/article/details/113865330)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值