大数据教程(8.5)mapreduce原理之并行度

        上一篇博客介绍了mapreduce的移动流量分析的实战案例,本篇将继续分享mapreduce的并行度原理。node

    1、mapTask并行度的决定机制服务器

          一个job的map阶段并行度由客户端在提交Job是决定,而客户端对map阶段并行度的规划的基本逻辑为:将待处理数据执行逻辑切片(即按照一个特定切片大小,将待处理数据划分红逻辑上的多个split),而后每个split分配一个mapTask并行实例处理;这段逻辑及造成的切片规划描述文件,由FileInputFormat实现类的getSplits()方法完成,其过程以下图:并发

        (1)FileInputFormat切片机制jvm

                切片定义在InputFormat类中的getSplit()方法;FileInputFormat中默认的切片机制:a.简单地按照文件的内容长度进行切片,b.切片大小,默认等于block大小,c.切片时不考虑数据集总体,而是逐个针对每个文件单独切片
                好比待处理数据有两个文件:
                    file1.txt    320M
                    file2.txt    10M
                通过FileInputFormat的切片机制运算后,造成的切片信息以下:
                    file1.txt.split1-- 0~128
                    file1.txt.split2-- 128~256
                    file1.txt.split3-- 256~320
                    file2.txt.split1-- 0~10M              oop

        (2)FileInputFormat中切片的大小的参数配置
                 经过分析源码,在FileInputFormat中,计算切片大小的逻辑:Math.max(minSize, Math.min(maxSize, blockSize));  切片主要由这几个值来运算决定
                minsize:默认值:1      配置参数: mapreduce.input.fileinputformat.split.minsize    
                maxsize:默认值:Long.MAXValue      配置参数:mapreduce.input.fileinputformat.split.maxsize
                blocksize
                所以,默认状况下,切片大小=blocksize
                maxsize(切片最大值):参数若是调得比blocksize小,则会让切片变小,并且就等于配置的这个参数的值
                minsize (切片最小值):参数调的比blockSize大,则可让切片变得比blocksize还大大数据


            选择并发数的影响因素:一、运算节点的硬件配置,二、运算任务的类型:CPU密集型仍是IO密集型,三、运算任务的数据量3d

 

        (3)map并行度的经验之谈
                 若是硬件配置为2*12core + 64G,恰当的map并行度是大约每一个节点20-100个map,最好每一个map的执行时间至少一分钟。
                 若是job的每一个map或者 reduce task的运行时间都只有30-40秒钟,那么就减小该job的map或者reduce数,每个task(map|reduce)的setup和加入到调度器中进行调度,这个中间的过程可能都要花费几秒钟,因此若是每一个task都很是快就跑完了,就会在task的开始和结束的时候浪费太多的时间。
配置task的JVM重用[JVM重用技术不是指同一Job的两个或两个以上的task能够同时运行于同一JVM上,而是排队按顺序执行。]能够改善该问题:
(mapred.job.reuse.jvm.num.tasks,默认是1,表示一个JVM上最多能够顺序执行的task数目(属于同一个Job)是1。也就是说一个task启一个JVM)调试

                 若是input的文件很是的大,好比1TB,能够考虑将hdfs上的每一个block size设大,好比设成256MB或者512MBcode

 

    2、ReduceTask并行度的决定
           reducetask的并行度一样影响整个job的执行并发度和执行效率,但与maptask的并发数由切片数决定不一样,Reducetask数量的决定是能够直接手动设置:orm

//默认值是1,手动设置为4
job.setNumReduceTasks(4);

           若是数据分布不均匀,就有可能在reduce阶段产生数据倾斜
           注意: reducetask数量并非任意设置,还要考虑业务逻辑需求,有些状况下,须要计算全局汇总结果,就只能有1个reducetask

           尽可能不要运行太多的reduce task。对大多数job来讲,最好rduce的个数最多和集群中的reduce持平,或者比集群的 reduce slots小。这个对于小集群而言,尤为重要。

    3、mapreduce调试

           能够在本地运行mapreduce,配置远程的namenode主机对应的输入路径和输出路径进行远程调试,调试入口: boolean res = job.waitForCompletion(true);

           强烈建议小伙伴们进行一次完整的调试以理解mapreduce的切片规划和提交原理。

    4、切片规划

           切片规划是通常会造成几个文件: job.xml(hadoop配置参数)、job.split(切片信息)、job.splitmetainfo(切片meta信息)

    最后寄语,以上是博主本次文章的所有内容,若是你们以为博主的文章还不错,请点赞;若是您对博主其它服务器大数据技术或者博主本人感兴趣,请关注博主博客,而且欢迎随时跟博主沟通交流。

相关文章
相关标签/搜索