【大数据优化】(二)MapReduce 优化方法

简介: 【大数据优化】(二)MapReduce 优化方法

MapReduce跑的慢的原因(☆☆☆☆☆)


一、Mapreduce 程序效率的瓶颈在于两点:


1) 计算机性能


CPU、内存、磁盘健康、网络


2) I/O 操作优化


(1) 数据倾斜

(2) map 和reduce 数设置不合理

(3) reduce 等待过久

(4) 小文件过多

(5) 大量的不可分块的超大文件

(6) spill 次数过多

(7) merge 次数过多等。


二、MapReduce优化方法(☆☆☆☆☆)


1)数据输入:


(1)合并小文件:在执行mr 任务前将小文件进行合并,大量的小文件会产生大量的map 任务,增

大map 任务装载次数,而任务的装载比较耗时,从而导致mr 运行较慢。

(2)采用ConbinFileInputFormat 来作为输入,解决输入端大量小文件场景。


2)map 阶段


(1)减少spill 次数:通过调整io.sort.mb 及sort.spill.percent 参数值,增大触发spill 的内存上限,

减少spill 次数,从而减少磁盘IO。

(2)减少merge 次数:通过调整io.sort.factor 参数,增大merge 的文件数目,减少merge 的次数,

从而缩短mr 处理时间。

(3)在map 之后先进行combine 处理,减少I/O。


3)reduce 阶段


(1)合理设置map 和reduce 数:两个都不能设置太少,也不能设置太多。太少,会导致task 等

待,延长处理时间;太多,会导致map、reduce 任务间竞争资源,造成处理超时等错误。

(2)设置map、reduce 共存:调整slowstart.completedmaps 参数,使map 运行到一定程度后,reduce

也开始运行,减少reduce 的等待时间。

(3)规避使用reduce,因为Reduce 在用于连接数据集的时候将会产生大量的网络消耗。

(4)合理设置reduc 端的buffer,默认情况下,数据达到一个阈值的时候,buffer 中的数据就会写入磁盘,然后reduce 会从磁盘中获得所有的数据。也就是说,buffer 和educe 是没有直接关联的,中间多个一个写磁盘->读磁盘的过程,既然有这个弊端,那么就可以通过参数来配置,使得buffer 中的一部分数据可以直接输送到reduce,从而减少IO 开销:mapred.job.reduce.input.buffer.percent,默认为0.0。当值大于0 的时候,会保留指定比例的内存读buffer 中的数据直接拿给reduce 使用。这样一来,设置buffer 需要内存,读取数据需要内存,reduce 计算也要内存,所以要根据作业的运行情况进行调整。


4)IO 传输


(1)采用数据压缩的方式,减少网络IO 的的时间。安装Snappy 和LZOP 压缩编码器。

(2)使用SequenceFile 二进制文件


5)数据倾斜问题


(1)数据倾斜现象

数据频率倾斜——某一个区域的数据量要远远大于其他区域。数据大小倾斜——部分记录的大小远远大于平均值。

(2)如何收集倾斜数据

在reduce 方法中加入记录map 输出键的详细情况的功能。

public static final String MAX_VALUES = "skew.maxvalues";
private int maxValueThreshold;
@Override
public void configure(JobConf job) {
maxValueThreshold = job.getInt(MAX_VALUES, 100);
}
@Override
public void reduce(Text key, Iterator<Text> values, OutputCollector<Text, Text> output, Reporter reporter) throws IOException {
  int i = 0;
  while (values.hasNext()) {
  values.next();
  i++;
  }
  if (++i > maxValueThreshold) {
  log.info("Received " + i + " values for key " + key);
  }
}


(3)减少数据倾斜的方法


方法1:抽样和范围分区

      可以通过对原始数据进行抽样得到的结果集来预设分区边界值。


方法2:自定义分区

      另一个抽样和范围分区的替代方案是基于输出键的背景知识进行自定义分区。例如,如果map 输出键的单词来源于一本书。其中大部分必然是省略词(stopword)。那么就可以将自定义分区将这部分省略词发送给固定的一部分reduce 实例。而将其他的都发送给剩余的reduce 实例。


方法3:Combine

      使用Combine 可以大量地减小数据频率倾斜和数据大小倾斜。在可能的情况下,

combine 的目的就是聚合并精简数据。


6) 常用的调优参数


(1) 资源相关参数

      (a) 以下参数是在用户自己的mr 应用程序中配置就可以生效(mapred-default.xml)


20200106194304782.png


      (b)应该在yarn 启动之前就配置在服务器的配置文件中才能生效(yarn-default.xml)


20200106194443323.png


      (c)shuffle 性能优化的关键参数,应在yarn 启动之前就配置好(mapred-default.xml)


20200106194509249.png


(2) 容错相关参数(mapreduce 性能优化)


20200106194540138.png

相关实践学习
基于MaxCompute的热门话题分析
Apsara Clouder大数据专项技能认证配套课程:基于MaxCompute的热门话题分析
目录
相关文章
|
5月前
|
存储 分布式计算 大数据
MaxCompute聚簇优化推荐功能发布,单日节省2PB Shuffle、7000+CU!
MaxCompute全新推出了聚簇优化推荐功能。该功能基于 31 天历史运行数据,每日自动输出全局最优 Hash Cluster Key,对于10 GB以上的大型Shuffle场景,这一功能将直接带来显著的成本优化。
284 3
|
5月前
|
数据采集 搜索推荐 Java
Java 大视界 -- Java 大数据在智能教育虚拟学习环境构建与用户体验优化中的应用(221)
本文探讨 Java 大数据在智能教育虚拟学习环境中的应用,涵盖多源数据采集、个性化推荐、实时互动优化等核心技术,结合实际案例分析其在提升学习体验与教学质量中的成效,并展望未来发展方向与技术挑战。
|
6月前
|
数据采集 搜索推荐 算法
大数据信息SEO优化系统软件
大数据信息SEO优化系统软件(V1.0)是公司基于“驱动企业价值持续增长”战略,针对企业网站、电商平台及内容营销场景深度定制的智能化搜索引擎优化解决方案。该软件以“提升搜索排名、精准引流获客”为核心目标,通过整合全网数据采集、智能关键词挖掘、内容质量分析、外链健康度监测等功能模块,为企业构建从数据洞察到策略落地的全链路SEO优化体系,助力品牌高效提升搜索引擎曝光度,实现从流量获取到商业转化的价值升级。
139 2
|
7月前
|
资源调度 安全 Java
Java 大数据在智能教育在线实验室设备管理与实验资源优化配置中的应用实践
本文探讨Java大数据技术在智能教育在线实验室设备管理与资源优化中的应用。通过统一接入异构设备、构建四层实时处理管道及安全防护双体系,显著提升设备利用率与实验效率。某“双一流”高校实践显示,设备利用率从41%升至89%,等待时间缩短78%。该方案降低管理成本,为教育数字化转型提供技术支持。
210 1
|
4月前
|
存储 SQL 分布式计算
MaxCompute 聚簇优化推荐原理
基于历史查询智能推荐Clustered表,显著降低计算成本,提升数仓性能。
323 4
MaxCompute 聚簇优化推荐原理
|
4月前
|
存储 并行计算 算法
【动态多目标优化算法】基于自适应启动策略的混合交叉动态约束多目标优化算法(MC-DCMOEA)求解CEC2023研究(Matlab代码实现)
【动态多目标优化算法】基于自适应启动策略的混合交叉动态约束多目标优化算法(MC-DCMOEA)求解CEC2023研究(Matlab代码实现)
237 4
|
4月前
|
大数据 数据挖掘 定位技术
买房不是拍脑袋:大数据教你优化房地产投资策略
买房不是拍脑袋:大数据教你优化房地产投资策略
215 2
|
5月前
|
存储 人工智能 算法
Java 大视界 -- Java 大数据在智能医疗影像数据压缩与传输优化中的技术应用(227)
本文探讨 Java 大数据在智能医疗影像压缩与传输中的关键技术应用,分析其如何解决医疗影像数据存储、传输与压缩三大难题,并结合实际案例展示技术落地效果。
|
5月前
|
机器学习/深度学习 算法 Java
Java 大视界 -- Java 大数据机器学习模型在生物信息学基因功能预测中的优化与应用(223)
本文探讨了Java大数据与机器学习模型在生物信息学中基因功能预测的优化与应用。通过高效的数据处理能力和智能算法,提升基因功能预测的准确性与效率,助力医学与农业发展。
|
5月前
|
机器学习/深度学习 算法 Java
Java 大视界 -- Java 大数据在智能物流运输车辆智能调度与路径优化中的技术实现(218)
本文深入探讨了Java大数据技术在智能物流运输中车辆调度与路径优化的应用。通过遗传算法实现车辆资源的智能调度,结合实时路况数据和强化学习算法进行动态路径优化,有效提升了物流效率与客户满意度。以京东物流和顺丰速运的实际案例为支撑,展示了Java大数据在解决行业痛点问题中的强大能力,为物流行业的智能化转型提供了切实可行的技术方案。