MapReduce优化

1MapReduce 跑的慢的原因
  1. 系统资源限制:内存、CPU
  2. I/O问题
    • 小文件太多
    • 超大文件不能切片
    • Map和Reduce参数设置不合理
    • Map运行太长,Reduce等待太久
    • 溢写次数太多
    • merge合并次数太多
2 MapReduce优化方法

MapReduce优化方法主要从六个方面考虑:数据输入、Map阶段、Reduce阶段、IO传输、数据倾斜问题和常用的调优参数。

  1. 数据输入:合并小文件:CombineTextInputFormat
  2. Map 阶段:
    • 减少溢写次数:增大内存存储上限,减少溢写次数
    • 减少merge合并次数:增大merge文件数,减少合并次数,缩短MR处理时间
    • Map后,不影响业务逻辑下,提前combine出来,减少i/o
  3. Reduce阶段:
    • 合理设置Map和Reduce个数:太少使task等待时间长;太多hi竞争资源
    • 在Map运行到一定程度后,让Reduce也开始运行,减少等待时间
    • 尽量不用Reduce
    • 合理设置Reduce短的buffer
  4. IO传输
    • 采用数据压缩方式:Snappy[速度非常快]和LZO[可切片]压缩;bzips:精度高,速度慢
    • 使用SequenceFile二进制文件
  5. 数据倾斜问题
  6. 常用调优参数
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值