当前位置: 首页 > article >正文

Spark常见面试题整理

Spark常见面试题整理

之前写过不少SparkMLlib和SparkGraphX的应用,但是一直都没有像Flink那样系统的写过它的架构和API等,一方面是它们有很多类似的情况,基本都是一通百通,另一方面是确实懒,最近两天整理文档翻到之前整理的一些面试题和工作中积累的一些有关Spark的问题,再整理一下发出来~

文章目录

  • Spark常见面试题整理
  • 1、Spark中如何优化Join操作?
  • 2、数据倾斜问题具体指的是什么,一般怎么解决?
  • 3、Spark中的缓存级别?
  • 4、Spark中的窄依赖和宽依赖分别指的是什么?
  • 5、Spark中的任务和阶段分别指的是什么?
  • 6、Spark中缓存和检查点(Checkpoint)的区别?
  • 总结


1、Spark中如何优化Join操作?

分两种情况,一是小表Join大表,二是大表Join大表(小表Join小表,没有优化的必要),这里表的书法只是一种泛指,Spark中的join操作通用,包括RDD的Join。

  • 小表Join大表
  • 大表Join大表

Spark中如何优化Join操作?

2、数据倾斜问题具体指的是什么,一般怎么解决?

数据倾斜指的是数据在各个节点(执行器)之间分布不均衡,导致部分节点处理的数据量远多于其他节点(Spark和数仓中的数据倾斜本质是一个意思)。

Spark中常见的出现数据倾斜的原因:

  • 数据分布本身就不均匀:比如电商行业存在一些热门商品,游戏行业存在一些热门礼包
  • join或groupBy键的分布不均:如果进行这些操作时所依赖的键本身分布就是极不均衡的,某些键对应的数据量非常大,就会出现大量数据都分布在一个节点的问题即出现数据倾斜问题。
  • 默认的分区策略不适用:Spark 默认使用哈希分区来分配数据。如果数据的键经过哈希后,不能均匀地分布在不同的分区,也会造成数据倾斜。

数据倾斜解决方案

3、Spark中的缓存级别?

缓存机制能提高程序运行速度的原因是什么?

4、Spark中的窄依赖和宽依赖分别指的是什么?

Spark中的窄依赖和宽依赖分别指的是什么?

5、Spark中的任务和阶段分别指的是什么?

阶段是 Spark 执行过程中的一个关键概念。一个 Spark 作业由一系列的阶段组成,每个阶段包含对数据的一组并行操作。阶段的划分基本上由宽依赖(Shuffle 依赖)决定。(即如果一个操作,如 reduceByKey() 或 groupBy(),需要数据重新分配(Shuffle),Spark 会结束当前阶段并启动一个新阶段,因为这些操作需要从多个节点读取和重新组合数据,对于不需要大规模数据重组的操作(如 map()、filter()),可以在同一阶段内连续处理,因为这些操作仅涉及单个或少数几个父分区的数据处理)每当一个操作引入了宽依赖,Spark 就会结束当前的阶段并开始一个新阶段。

6、Spark中缓存和检查点(Checkpoint)的区别?

核心区别:是否切断血缘依赖
Spark中缓存和检查点(Checkpoint)的区别?


总结

在这里插入图片描述


http://www.kler.cn/a/292361.html

相关文章:

  • Python调用API翻译Excel中的英语句子并回填数据
  • 直接映射缓存配置
  • jvm调优方式
  • redis linux 安装
  • core 文件
  • 民事诉讼中,火灾事故认定书并非不可推翻,其证明力弱于鉴定意见
  • 二进制基础和STM32的常用位运算
  • YOLOv8 classify介绍
  • JavaScript - Api学习 Day03 (日期对象、节点操作、两种定时器、本地存储)
  • Mysql中的隐式COMMIT以及Savepoints的作用以及MySQL的Innodb分空间存储、设计优化、索引等几个小知识点整理
  • 鸿蒙OS创新实践:动态声控话筒开发指南
  • Anthropic发布Claude企业计划 对标OpenAI的ChatGPT Enterprise
  • 【Python百日进阶-Web开发-音频】Day708 - 时域处理 librosa.lpc
  • k8s执行crictl images报错
  • 代码随想录训练营 Day51打卡 图论part02 99. 岛屿数量 100. 岛屿的最大面积
  • 利用全核范数去噪技术优化彩色图像处理
  • llamafactory微调llama3.1
  • 2024 数学建模高教社杯 国赛(A题)| “板凳龙”舞龙队 | 建模秘籍文章代码思路大全
  • 本地 springboot 项目如何使用 https 进行访问
  • Java项目:141 springboot大学生智能消费记账系统的设计与实现
  • 拥抱分布式云:云基础设施的下个新时代
  • 目标检测-YOLOv1
  • IDEA运行Java程序提示“java: 警告: 源发行版 11 需要目标发行版 11”
  • java项目热部署
  • 蚂蚁SEO|AI养站程序是什么|蚂蚁蜘蛛池
  • 职场关系课:职场上的基本原则(安全原则、进步原则、收益原则、逃生舱原则)