最具影响力的数字化技术在线社区

168大数据

 找回密码
 立即注册

QQ登录

只需一步,快速开始

1 2 3 4 5
打印 上一主题 下一主题
开启左侧

Spark性能优化第二季

[复制链接]
跳转到指定楼层
楼主
发表于 2017-7-4 15:17:43 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多数据大咖,获取更多知识干货,轻松玩转大数据

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
一:Task性能优化
1,慢任务(数据倾斜或机器故障)的性能优化:可以考虑减少每个partition处理的数据量,同时建议开启Spark.speculation;
2,尽量减少Shuffle,例如我们要减少groupByKey的操作,因为groupByKey会要求通过网络拷贝(Shuffle)所有的数据,有限考虑使用reduceByKey,因为会首先reduce locally;再例如在进行join操作的时候,形如(K1,V1)和(K1,V2)=> (K1,V3)此时就可以进行pipeline,但是(o1)join(o2)=>o3,此时就会产生Shuffle操作;
3,Repatition:增加Task数量的时候可以考虑使用,从而更加充分使用计算资源;Coalesce整理Partition碎片;当partition分片数量由大变小要用Coalesce(其中shuffle=false),而Repartition是无论如何都进行Shuffle;
二:数据倾斜:一般发生在Shuffle
1,定义更加合理的Key(或者说自定义Partitioner)。
2,可以考虑使用ByteBuffer来存储Block,最大的存储数据为2G,如果超过这个大小会报异常;
三:网络性能优化
1,可以考虑Shuffle的数据放在Tachyon中带来更好的数据本地性,减少网络的Shuffle;
2,优先采用Netty的方式进行网络通信;
3,广播:例如进行Join操作的时候采用Broadcast可以达到完全的数据本地性的情况下进行Join操作;
4,mapPartitions中的函数会直接作用于整个Partition(一次!!!);
5,最优先考虑是PROCESS_LOCAL(Spark默认情况下也是这样做的),所以你更应该考虑使用Tachyon;
6,如果要访问Hbase或Canssandra,务必保证数据处理发送在数据所在的机器上;可以参考华为的astro的项目中的Task本地化的实现
ps:前面的Stage执行完了才能执行下一个Stage,前面的Stage中的任一Task没完成,说明这个Stage还没完成,无法进行下一个Stage作业。

楼主热帖
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 转播转播 分享分享 分享淘帖 赞 踩

168大数据 - 论坛版权1.本主题所有言论和图片纯属网友个人见解,与本站立场无关
2.本站所有主题由网友自行投稿发布。若为首发或独家,该帖子作者与168大数据享有帖子相关版权。
3.其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和168大数据的同意,并添加本文出处。
4.本站所收集的部分公开资料来源于网络,转载目的在于传递价值及用于交流学习,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。
5.任何通过此网页连接而得到的资讯、产品及服务,本站概不负责,亦不负任何法律责任。
6.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源,若标注有误或遗漏而侵犯到任何版权问题,请尽快告知,本站将及时删除。
7.168大数据管理员和版主有权不事先通知发贴者而删除本文。

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

站长推荐上一条 /1 下一条

关于我们|小黑屋|Archiver|168大数据 ( 京ICP备14035423号|申请友情链接

GMT+8, 2024-6-4 00:42

Powered by BI168大数据社区

© 2012-2014 168大数据

快速回复 返回顶部 返回列表