首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

大数据开发岗面试复习30天冲刺 - 日积月累,每日五题【Day29】——数据倾斜2

解决方案:避免数据源的数据倾斜 实现原理:通过在Hive中对倾斜的数据进行预处理,以及在进行kafka数据分发时尽量进行平均分配。这种方案从根源上解决了数据倾斜,彻底避免了在Spark中执行shuffle类算子,那么肯定就不会有数据倾斜的问题了。 方案优点:实现起来简单便捷,效果还非常好,完全规避掉了数据倾斜,Spark作业的性能会大幅度提升。 方案缺点:治标不治本,Hive或者Kafka中还是会发生数据倾斜。 适用情况:在一些Java系统与Spark结合使用的项目中,会出现Java代码频繁调用Spark作业的场景,而且对Spark作业的执行性能要求很高,就比较适合使用这种方案。将数据倾斜提前到上游的Hive ETL,每天仅执行一次,只有那一次是比较慢的,而之后每次Java调用Spark作业时,执行速度都会很快,能够提供更好的用户体验。 总结:前台的Java系统和Spark有很频繁的交互,这个时候如果Spark能够在最短的时间内处理数据,往往会给前端有非常好的体验。这个时候可以将数据倾斜的问题抛给数据源端,在数据源端进行数据倾斜的处理。但是这种方案没有真正的处理数据倾斜问题。

02

Spark RDD 整体介绍

RDD 介绍     RDD 弹性分布式数据集          弹性:具有容错性,在节点故障导致丢失或者分区损坏,可以进行重新计算数据         分布式: 数据分布式存储,分布式计算(分布式执行)         数据集:传统意义上的数据集,不过这个数据集不是真实存在的,只是一个代理,正真数据集的获取 需要通过Task来或者     RDD 真正意义上不存储数据,只是代理,任务代理,对RDD的每次操作都会根据Task的类型转换成Task进行执行     Spark中关于RDD的介绍:         1. 分区列表(分区有编号,分区中包含的切片迭代器)         2. 提供了切片的计算入口函数(RDD具有一些列的函数(Trans/Action))         3. 其他RDD的一系列依赖(一个RDD 可以依赖于其他RDD)         4. (可选) 分区RDD (一个RDD也可以是一个分区RDD,可以对分区RDD进行处理)         5. (可选) 对RDD提供了一系列的计算函数 (RDD提供了对一些了切片的首选执行方法)     RDD 有俩类函数,transformations (懒加载)/Action(立即执行)     transformations 与Action最明显的区别在于:         1. transformations  为懒函数,action是实时函数         2. transformations 执行完毕后任然为RDD ,但是Action 执行完毕为 scala数据类型。     transformations函数为懒加载函数,调用该函数时函数不会立即执行,只记录函数执行操作,相当于pipeline,只是定义了RDD的执行过程,只有当Action函数出发以后,才会调用前面的Transformation。     Action函数为实时函数,执行了就会通过Master下发Task任务到Worker端,执行相应的处理。     transformations类函数:此类函数只会记录RDD执行逻辑,并不正真下发任务执行数据处理     函数列表:

01

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券