fileinputformatmapreduce 键值对怎么定义的

fileinputformat  时间:2021-06-08  阅读:()

hadoop怎么重新启动tasktracker

如果是某个TaskTracker挂掉了想要重启,比较稳妥的方式是在master直接运行一次start-mapred.sh(或者start-all.sh也可以)脚本。

脚本会忽略正在正常运行的hadoop进程,并在没有运行TaskTracker的节点上启动TaskTracker。

如果是想停止某个节点上的Taskracker再启动,直接登录到该节点,kill掉TaskTracker进程,再返回master运行start-mapred.sh。

Hadoop,怎么实现多个输入路径的输入?

1.多路径输入 1)FileInputFormat.addInputPath 多次调用加载不同路径 .apache.hadoop.mapreduce.lib.input.FileInputFormat; .apache.hadoop.mapreduce.lib.output.FileOutputFormat; String?in0?=?args[0]; String?in1?=?args[1]; String?out?=?args[2]; FileInputFormat.addInputPath(job,new?Path(in0)); FileInputFormat.addInputPath(job,new?Path(in1)); FileOutputFormat.setOutputPath(job,new?Path(out));2)FileInputFormat.addInputPaths一次调用加载 多路径字符串用逗号隔开 FileInputFormat.addInputPaths(job, "hdfs://RS5-112:9000/cs/path1,hdfs://RS5-112:9000/cs/path2"); 2.多种输入 MultipleInputs可以加载不同路径的输入文件,并且每个路径可用不同的maper MultipleInputs.addInputPath(job, new Path("hdfs://RS5-112:9000/cs/path1"), TextInputFormat.class,MultiTypeFileInput1Mapper.class); MultipleInputs.addInputPath(job, new Path("hdfs://RS5-112:9000/cs/path3"), TextInputFormat.class,MultiTypeFileInput3Mapper.class);

Hadoop是怎么分块的

hadoop的分块有两部分,其中第一部分更为人熟知一点。

第一部分就是数据的划分(即把File划分成Block),这个是物理上真真实实的进行了划分,数据文件上传到HDFS里的时候,需要划分成一块一块,每块的大小由hadoop-default.xml里配置选项进行划分。

<property> <name>dfs.block.size</name> <value>67108864</value> <description>The default block size for new files.</description> </property> 这个就是默认的每个块64MB。

数据划分的时候有冗余,个数是由 <property> <name>dfs.replication</name> <value>3</value> <description>Default block replication. The actual number of replications can be specified when the file is created. The default is used if replication is not specified in create time. </description> </property> 指定的。

具体的物理划分步骤要看Namenode,这里要说的是更有意思的hadoop中的第二种划分。

在hadoop中第二种划分是由InputFormat这个接口来定义的,其中有个getSplits方法。

这里就有了一个新的不为人熟知的概念:Split。

Split的作用是什么,Split和Block是什么关系,下面就可以说明清楚。

在Hadoop0.1中,split划分是在JobTracker端完成的,发生在JobInitThread对JobInProgress调用inittasks()的时候;而在0.18.3中是由JobClient完成的,JobClient划分好后,把split.file写入hdfs里,到时候jobtracker端只需要读这个文件,就知道Split是怎么划分的了。

第二种划分只是一种逻辑上划分,目的是为了让Map Task更好的获取数据输入,仔细分析如下这个场景: File 1 : Block11, Block 12, Block 13, Block 14, Block 15 File 2 : Block21, Block 22, Block 23 File1有5个Block,最后一个Block当然可能小于64MB;File2有3个Block 如果用户在程序中指定map tasks的个数,比如说是2(如果不指定的话maptasks个数默认是1),那么在 FileInputFormat(最常见的InputFormat实现)的getSplits方法中,首先会计算totalSize=8(可以对照源码看看,注意getSplits这个函数里的计量单位是Block个数,而不是Byte个数,后面有个变量叫bytesremaining仍然表示剩余的Block个数,有些变量名让人无语),然后会计算goalSize=totalSize/numSplits=4,对于File1,计算一个Split有多少个Block是这样计算的 long splitSize =puteSplitSize(goalSize, minSize, blockSize); protected puteSplitSize(long goalSize, long minSize, long blockSize) { return Math.max(minSize, Math.min(goalSize, blockSize)); } 这里minSize是1(说明了一个Split至少包含一个Block,不会出现一个Split包含零点几个Block的情况),计算得出splitSize=4,所以接下来Split划分是这样分的: Split 1: Block11, Block12, Block13,Block14 Split 2: Block15 Split 3: Block21, Block22, Block23 那用户指定的map个数是2,出现了三个split怎么办?在JobInProgress里其实maptasks的个数是根据Splits的长度来指定的,所以用户指定的map个数只是个参考。

可以参看JobInProgress: initTasks() 里的代码: try { splits = JobClient.readSplitFile(splitFile); } finally { splitFile.close(); } numMapTasks = splits.length; maps = new TaskInProgress[numMapTasks]; 所以问题就很清晰了,还如果用户指定了20个map作业,那么最后会有8个Split(每个Split一个Block),所以最后实际上就有8个MapTasks,也就是说maptask的个数是由splits的长度决定的。

几个简单的结论: 1. 一个split不会包含零点几或者几点几个Block,一定是包含大于等于1个整数个Block 2. 一个split不会包含两个File的Block,不会跨越File边界 3. split和Block的关系是一对多的关系 4. maptasks的个数最终决定于splits的长度 还有一点需要说明,在FileSplit类中,有一项是private String[] hosts; 看上去是说明这个FileSplit是放在哪些机器上的,实际上hosts里只是存储了一个Block的冗余机器列表。

比如上面例子中的Split 1: Block11, Block12, Block13,Block14,这个FileSplit中的hosts里最终存储的是Block11本身和其冗余所在的机器列表,也就是说Block12,Block13,Block14存在哪些机器上没有在FileSplit中记录。

FileSplit中的这个属性有利于调度作业时候的数据本地性问题。

如果一个tasktracker前来索取task,jobtracker就会找个task给他,找到一个maptask,得先看这个task的输入的FileSplit里hosts是否包含tasktracker所在机器,也就是判断和该tasktracker同时存在一个机器上的datanode是否拥有FileSplit中某个Block的备份。

但总之,只能牵就一个Block,其他Block就从网络上传罢。

mapreduce怎么导入hbace

1、先看一个标准的hbase作为数据读取源和输出源的样例: [java] view plaincopy在CODE上查看代码片派生到我的代码片 Configuration conf = HBaseConfiguration.create(); Job job = new Job(conf, "job name "); job.setJarByClass(test.class); Scan scan = new Scan(); TableMapReduceUtil.initTableMapperJob(inputTable, scan, mapper.class, Writable.class, Writable.class, job); TableMapReduceUtil.initTableReducerJob(outputTable, reducer.class, job); job.waitForCompletion(true); 首先创建配置信息和作业对象,设置作业的类。

这些和正常的mapreduce一样, [java] view plaincopy在CODE上查看代码片派生到我的代码片 Configuration conf = HBaseConfiguration.create(); Job job = new Job(conf, "job name "); job.setJarByClass(test.class); Scan scan = new Scan(); TableMapReduceUtil.initTableMapperJob(inputTable, scan, mapper.class, Writable.class, Writable.class, job); TableMapReduceUtil.initTableReducerJob(outputTable, reducer.class, job); job.waitForCompletion(true); 唯一不一样的就是数据源的说明部分,TableMapReduceUtil的initTableMapperJob和initTableReducerJob方法来实现。

用如上代码: 数据输入源是hbase的inputTable表,执行mapper.class进行map过程,输出的key/value类型是ImmutableBytesWritable和Put类型,最后一个参数是作业对象。

需要指出的是需要声明一个扫描读入对象scan,进行表扫描读取数据用,其中scan可以配置参数,这里为了例子简单不再详述。

数据输出目标是hbase的outputTable表,输出执行的reduce过程是reducer.class类,操作的作业目标是job。

与map比缺少输出类型的标注,因为他们不是必要的,看过源代码就知道mapreduce的TableRecordWriter中write(key,value)方法中,key值是没有用到的。

value只能是Put或者Delete两种类型,write方法会自行判断并不用用户指明。

接下来就是mapper类: [java] view plaincopy在CODE上查看代码片派生到我的代码片 public class mapper extends TableMapper { public void map(Writable key, Writable value, Context context) throws IOException, InterruptedException { //mapper逻辑 context.write(key, value); } } } 继承的是hbase中提供的TableMapper类,其实这个类也是继承的MapReduce类。

后边跟的两个泛型参数指定类型是mapper输出的数据类型,该类型必须继承自Writable类,例如可能用到的put和delete就可以。

需要注意的是要和initTableMapperJob方法指定的数据类型一直。

该过程会自动从指定hbase表内一行一行读取数据进行处理。

然后reducer类: [java] view plaincopy在CODE上查看代码片派生到我的代码片 public class countUniteRedcuer extends TableReducer { public void reduce(Text key, Iterable values, Context context) throws IOException, InterruptedException { //reducer逻辑 context.write(null, put or delete); } } reducer继承的是TableReducer类。

后边指定三个泛型参数,前两个必须对应map过程的输出key/value类型,第三个必须是put或者delete。

write的时候可以把key写null,它是不必要的。

这样reducer输出的数据会自动插入outputTable指定的表内。

2、有时候我们需要数据源是hdfs的文本,输出对象是hbase。

这时候变化也很简单: [java] view plaincopy 你会发现只需要像平常的mapreduce的作业声明过程一样,指定mapper的执行类和输出key/value类型,指定FileInputFormat.setInputPaths的数据源路径,输出声明不变。

便完成了从hdfs文本读取数据输出到hbase的命令声明过程。

mapper和reducer如下: [java] view plaincopy在CODE上查看代码片派生到我的代码片 Configuration conf = HBaseConfiguration.create(); Job job = new Job(conf, "job name "); job.setJarByClass(test.class); job.setMapperClass(mapper.class); job.setMapOutputKeyClass(Text.class); job.setMapOutputValueClass(LongWritable.class); FileInputFormat.setInputPaths(job, path); TableMapReduceUtil.initTableReducerJob(tableName, reducer.class, job); [java] view plaincopy在CODE上查看代码片派生到我的代码片 public class mapper extends Mapper { public void map(LongWritable key, Text line, Context context) { //mapper逻辑 context.write(k, one); } } public class redcuer extends TableReducer { public void reduce(Writable key, Iterable values, Context context) throws IOException, InterruptedException { //reducer逻辑 context.write(null, put or delete); } } [java] view plaincopy mapper还依旧继承原来的MapReduce类中的Mapper即可。

同样注意这前后数据类型的key/value一直性。

[java] view plaincopy 3、最后就是从hbase中的表作为数据源读取,hdfs作为数据输出,简单的如下: [java] view plaincopy在CODE上查看代码片派生到我的代码片 Configuration conf = HBaseConfiguration.create(); Job job = new Job(conf, "job name "); job.setJarByClass(test.class); Scan scan = new Scan(); TableMapReduceUtil.initTableMapperJob(inputTable, scan, mapper.class, Writable.class, Writable.class, job); job.setOutputKeyClass(Writable.class); job.setOutputValueClass(Writable.class); FileOutputFormat.setOutputPath(job, Path); job.waitForCompletion(true); mapper和reducer简单如下: [java] view plaincopy在CODE上查看代码片派生到我的代码片Configuration conf = HBaseConfiguration.create(); Job job = new Job(conf, "job name "); job.setJarByCl ass(test.class); Scan scan = new Scan(); TableMapReduceUtil.initTableMapperJob(inputTable, scan, mapper.class, Writable.class, Writable.class, job); TableMapReduceUtil.initTableReducerJob(outputTable, reducer.class, job); job.waitForCompletion(true); Configuration conf = HBaseConfiguration.create(); Job job = new Job(conf, "job name "); job.setJarByClass(test.class); Scan scan = new Scan(); TableMapReduceUtil.initTableMapperJob(inputTable, scan, mapper.class, Writable.class, Writable.class, job); TableMapReduceUtil.initTableReducerJob(outputTable, reducer.class, job); job.waitForCompletion(true); 唯一不一样的就是数据源的说明部分,TableMapReduceUtil的initTableMapperJob和initTableReducerJob方法来实现。

public class mapper extends TableMapper { public void map(Writable key, Writable value, Context context) throws IOException, InterruptedException { //mapper逻辑 context.write(key, value); } } } public class countUniteRedcuer extends TableReducer { public void reduce(Text key, Iterable values, Context context) throws IOException, InterruptedException { //reducer逻辑 context.write(null, put or delete); } }

mapreduce 键值对怎么定义的

一般情况下Mapreduce输出的键值对是以制表符 为分隔符的,如下图所示: 但有时候我们像将其设置为其它的分隔符输出,比如",",如下图所示: 此时可以在Mapreduce的主函数中添加如下的两行代码: [java] view plain copy print? conf.set("mapred.textoutputformat.ignoreseparator","true"); conf.set("mapred.textoutputformat.separator",","); 具体如下的WordCount程序: [java] view plain copy print? import java.io.IOException; import java.util.StringTokenizer; .apache.hadoop.conf.Configuration; .apache.hadoop.fs.Path; .apache.hadoop.io.IntWritable; .apache.hadoop.io.Text; .apache.hadoop.mapreduce.Job; .apache.hadoop.mapreduce.Mapper; .apache.hadoop.mapreduce.Reducer; .apache.hadoop.mapreduce.lib.input.FileInputFormat; .apache.hadoop.mapreduce.lib.output.FileOutputFormat; .apache.hadoop.util.GenericOptionsParser; public class WordCount { public static class TokenizerMapper extends Mapper<Object, Text, Text, IntWritable> { private final static IntWritable one = new IntWritable(1); private Text word = new Text(); public void map(Object key, Text value, Context context) throws IOException, InterruptedException { StringTokenizer itr = new StringTokenizer(value.toString()); while (itr.hasMoreTokens()) { word.set(itr.nextToken()); context.write(word, one); } } } public static class IntSumReducer extends Reducer<Text, IntWritable, Text, IntWritable> { private IntWritable result = new IntWritable(); public void reduce(Text key, Iterable<IntWritable> values, Context context) throws IOException, InterruptedException { int sum = 0; for (IntWritable val : values) { sum += val.get(); } result.set(sum); context.write(key, result); } } public static void main(String[] args) throws Exception { Configuration conf = new Configuration(); //设置MapReduce的输出的分隔符为逗号 conf.set("mapred.textoutputformat.ignoreseparator", "true"); conf.set("mapred.textoutputformat.separator", ","); String[] otherArgs = new GenericOptionsParser(conf, args) .getRemainingArgs(); if (otherArgs.length != 2) { System.err.println("Usage: wordcount <in> <out>"); System.exit(2); } Job job = new Job(conf, "word count"); job.setJarByClass(WordCount.class); job.setMapperClass(TokenizerMapper.class); job.setCombinerClass(IntSumReducer.class); job.setReducerClass(IntSumReducer.class); job.setOutputKeyClass(Text.class); job.setOutputValueClass(IntWritable.class); FileInputFormat.addInputPath(job, new Path(otherArgs[0])); FileOutputFormat.setOutputPath(job, new Path(otherArgs[1])); System.exit(job.waitForCompletion(true) ? 0 : 1); } }

[黑五]ProfitServer新加坡/德国/荷兰/西班牙VPS五折,不限流量KVM月付2.88美元起

ProfitServer已开启了黑色星期五的促销活动,一直到本月底,商家新加坡、荷兰、德国和西班牙机房VPS直接5折,无码直购最低每月2.88美元起,不限制流量,提供IPv4+IPv6。这是一家始于2003年的俄罗斯主机商,提供虚拟主机、VPS、独立服务器、SSL证书、域名等产品,可选数据中心包括俄罗斯、法国、荷兰、美国、新加坡、拉脱维亚、捷克、保加利亚等多个国家和地区。我们随便以一个数据中心为例...

天上云:香港大带宽物理机服务器572元;20Mbps带宽!三网CN2线路

天上云服务器怎么样?天上云是国人商家,成都天上云网络科技有限公司,专注于香港、美国海外云服务器的产品,有多年的运维维护经验。世界这么大 靠谱最重,我们7*24H为您提供服务,贴心售后服务,安心、省事儿、稳定、靠谱。目前,天上云香港大带宽物理机服务器572元;20Mbps带宽!三网CN2线路,香港沙田数据中心!点击进入:天上云官方网站地址香港沙田数据中心!线路说明 :去程中国电信CN2 +中国联通+...

Sharktech($49/月),10G端口 32GB内存,鲨鱼机房新用户赠送$50

Sharktech 鲨鱼机房商家我们是不是算比较熟悉的,因为有很多的服务商渠道的高防服务器都是拿他们家的机器然后部署高防VPS主机的,不过这几年Sharktech商家有自己直接销售云服务器产品,比如看到有新增公有云主机有促销活动,一般有人可能买回去自己搭建虚拟主机拆分销售的,有的也是自用的。有看到不少网友在分享到鲨鱼机房商家促销活动期间,有赠送开通公有云主机$50,可以购买最低配置的,$49/月的...

fileinputformat为你推荐
股价图简单易懂的股票图外加说明华为总裁女儿为啥姓孟孟晚舟是谁awvawv转换器哪里下?熊猫烧香病毒下载谁知道熊猫烧香病毒腾讯技术腾讯是什么东西?asp大马一句话木马中的大马和小马的作用各是什么?什么是生态系统生态系统的功能有什么?审计平台什么叫数据库审计系统?谷歌图片识别怎么通过一张GIF图在网上搜索出其出处(你们懂的...)以图搜图那个百度只找到了一模一样的..,有文本框透明word文本框的背景图片怎样调透明度
vps论坛 lnmp 狗爹 winhost 哈喽图床 tk域名 商家促销 权嘉云 免费防火墙 太原网通测速平台 搜索引擎提交入口 如何注册阿里云邮箱 Updog 512mb photobucket ledlamp 学生服务器 葫芦机 美国主机 hosts文件 更多