Spark GC 调优

我们的Spark环境目前主要问题是数据量大后一些task的GC Time 特别长,多则几分钟,少则几十秒,实在不能忍受。参考databricks的 Tuning Java Garbage Collection for Spark Applications对我们的环境优化后,效果比较明显。

选择垃圾收集器

如果分配给单个Executor的Heap足够大(我认为超过32G)时使用G1,否则使用Parallel。因为如果在Heap小于32G时使用G1,G1 region size默认小于16M,可能引发Humongous对象分配问题。
当然,使用G1可能也可能引起Executor异常退出,这时有两种解决方法:
1. 减少cores数量(就是减少当前Executor并行task的数量)
2. 增加老年代内存

测试验证

硬件环境:(64G+8cores+42T) * 4,用yarn管理,利用Spark SQL对124G,169个字段的数据用row_number函数除重,除重前1.6亿条,除重后1.5亿条:

executor-memoryexecutor-coresextraJavaOptionsMax GC TimeJob Duration
20g10-XX:+UseG1GC 60s32min
30g20-XX:+UseG1GC 2.0 min27min
36g20-XX:+UseG1GC 1.8 min26min
36g20-XX:+UseG1GC -XX:NewRatio=811 s23min
36g22-XX:+UseG1GC -XX:NewRatio=817 s25min
36g28-XX:+UseG1GC -XX:NewRatio=8 -XXConcGCThreads=2028 s22min
20g20-XX:+UseParallelGC -XX:+UseParallelOldGC50s25min
36g20-XX:+UseParallelGC -XX:+UseParallelOldGC17s25min
20g20-XX:+UseConcMarkSweepGC -XX:+UseParNewGC1.9min42min
36g20-XX:+UseConcMarkSweepGC -XX:+UseParNewGC1.7min34min

当内存比较小,在测试时也遇到了databricks遇到的两个问题。我们之前使用CMS的,现在改为G1,由之前的34min降为23min,性能提升还是比较明显的。

参考文档:
http://www.oracle.com/webfolder/technetwork/tutorials/obe/java/G1GettingStarted/index.html

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值