Spark专用名词

  • RDD —- resillient distributed dataset 弹性分布式数据集
  • Operation —- 作用于RDD的各种操作分为transformation和action
  • Job —- 作业,一个JOB包含多个RDD及作用于相应RDD上的各种operation
  • Stage —- 一个作业分为多个阶段
  • Partition —- 数据分区, 一个RDD中的数据可以分成多个不同的区
  • DAG —- Directed Acycle graph, 有向无环图,反应RDD之间的依赖关系
  • Narrow dependency —- 窄依赖,子RDD依赖于父RDD中固定的data partition
  • Wide Dependency —- 宽依赖,子RDD对父RDD中的所有data partition都有依赖
  • Caching Managenment —- 缓存管理,对RDD的中间计算结果进行缓存管理以加快整体的处理速度

Spark编程模型

下面是Spark的一个日志计数示例,该程序演示了Spark的计算模型:

下面是Spark运行时涉及的各组件的概况图:

从RDD转换和存储角度,用户程序对RDD通过多个函数进行操作,将RDD进行转换。Block Manager管理RDD的物理分区,每个Block就是节点上对应的一个数据块,可以存储在内存或磁盘。而RDD中的partition是一个逻辑数据块,对应相应的物理块Block。
本质上,一个RDD在代码中相当于是数据的一个元数据结构,存储着数据分区及其逻辑结构映射关系,存储着RDD之前的依赖转换关系。

作用于RDD上的操作分为transformantion和action。 经Transformation处理之后,数据集中的内容会发生更改,由数据集A转换成为数据集B;而经Action处理之后,数据集中的内容会被归约为一个具体的数值。
只有当RDD上有action时,该RDD及其父RDD上的所有operation才会被提交到cluster中真正的被执行。

Spark运行态

用Spark的术语来说,static view称为dataset-level view,而dynamic view称为parition-level view,关系如图所示:

在Spark中的task可以对应于线程,worker是一个个的进程,worker由driver来进行管理。

在源码阅读时,需要重点把握以下两大主线:

  • 静态视图static view 即 RDD, transformation and action
  • 动态视图dynamic view 即 life of a job,每一个job又分为多个stage,每一个stage中可以包含多个rdd及其transformation,这些stage又是如何映射成为task被distributed到cluster中

Spark调度机制

Spark应用提交后经历了一系列的转换,最后成为Task在每个节点上执行。
当有Action作用于某RDD时,该action会作为一个job被提交。
在提交的过程中,DAGScheduler模块介入运算,计算RDD之间的依赖关系。RDD之间的依赖关系就形成了DAG。
每一个Job被分为多个stage,划分stage的一个主要依据是当前计算因子的输入是否是确定的,如果是则将其分在同一个stage,避免多个stage之间的消息传递开销。
当stage被提交之后,由taskscheduler来根据stage来计算所需要的task,并将task提交到对应的worker。
大体概况如下图所示:

关于Spark的调度运行机制详见下一节的RDD详解中的介绍。

本文转自如下博客,所有权利归原作者所有。

转载请注明作者Jason Ding及其出处
GitCafe博客主页(http://jasonding1354.gitcafe.io/)
Github博客主页(http://jasonding1354.github.io/)
CSDN博客(http://blog.csdn.net/jasonding1354)
简书主页(http://www.jianshu.com/users/2bd9b48f6ea8/latest_articles)
Google搜索jasonding1354进入我的博客主页

【Spark】Spark基本概念相关推荐

  1. 分布式实时计算—Spark—Spark Core

    原文作者:bingoabin 原文地址:Spark Core 目录 一.Spark Core 1. 主要功能 2. Spark Core子框架 3. Spark架构 4. Spark计算模型 二.组件 ...

  2. Spark——Spark概述

    一.Spark是什么 二.Spark and Hadoop 在之前的学习中,Hadoop的MapReduce是大家广为熟知的计算框架,那为什么咱们还要学习新的计算框架Spark呢,这里就不得不提到Sp ...

  3. [Spark]Spark Streaming 指南四 输入DStreams和Receivers

    1. 输入DStream与Receiver 输入DStreams表示从源中获取输入数据流的DStreams.在指南一示例中,lines表示输入DStream,它代表从netcat服务器获取的数据流.每 ...

  4. Spark学习之概念了解

    Spark简介: Spark是一个快速且通用的集群计算模型: 1.Spark是快速的: 快速是指处理几T到几批数据量的时候,他的处理时间是几秒钟或几分钟,相对于hadoop的几分钟到几小时是非常快速的 ...

  5. 转: Spark 的核心概念 RDD

    转自:  https://juejin.im/post/6844903826953076750 1.RDD 概述 1.1 什么是 RDD ? RDD(Resilient Distributed Dat ...

  6. [Spark]Spark常用的优化方法

    目录 优化目的 Spark-core的优化 Yarn 模式下动态资源调度 Shuffle阶段调优 MapPartitions分区替换map计算结果 使用foreachPartitions替代forea ...

  7. spark -- Spark原理初探

    基本概念 http://spark.apache.org/docs/latest/cluster-overview.html ●名词解释 1.Application:指的是用户编写的Spark应用程序 ...

  8. spark spark streaming + kafka receiver方式消费消息

    2019独角兽企业重金招聘Python工程师标准>>> kafka + spark streaming 集群 前提: spark 安装成功,spark 1.6.0 zookeeper ...

  9. [Spark]Spark RDD 指南二 初始化

    1. 初始化 Spark程序必须做的第一件事是创建一个JavaSparkContext对象(Scala和Python中是SparkContext对象),它告诉Spark如何访问集群. 要创建Spark ...

  10. Spark~Spark介绍

    一.Spark介绍 Spark是用于大规模数据处理的统一分析引擎 Spark借鉴了MapReduce思想发展而来,保留了其分布式并行计算的优点并改进了其明显的缺陷.让中间数据存储在内存中提高了运行速度 ...

最新文章

  1. 如何通过在ViewPager中用手指轻扫来禁用分页,但是仍然能够以编程方式轻扫?
  2. Linux shell 正则表达式用法
  3. 万万没想到,分布式存储系统的一致性是......
  4. java isight zmf_isight集成catia和abaqus,nastran流程详解
  5. MongoDB查询性能分析—— explain 操作返回结果详解
  6. 《阿里云互联网多媒体存储解决方案蓝皮书》震撼上线!
  7. Scala变量和常用数据类型
  8. C++ Coding Standard
  9. vscode java settings设置_vscode 搭建java环境
  10. win10禁止自动更新
  11. MySQL数据库主键与外键
  12. 电信光猫DDNS的设置经历
  13. 登录服务器的详细步骤
  14. skyline在海洋及管线类3DGIS应用综述
  15. 如何向小白程序员解释区块链
  16. 控制理论PID的理解
  17. linux保险箱软件,手机加密App哪个好?手机加密软件推荐
  18. CentOS7 个性化
  19. 三值的排序 Sorting a Three-Valued Sequence(洛谷 P1459)
  20. Spring中的静态工厂与实例工厂

热门文章

  1. 课程设计之第二次冲刺----第八天
  2. WCF技术剖析(卷1)正式出版
  3. 春秋时期被误解的人才。
  4. delphi 中 的 Split 函数
  5. java基础教程知识点,[Java教程]js基础知识点总结
  6. 叨叨20220304
  7. 模拟——生活大爆炸版石头剪刀布(洛谷 P1328)
  8. 深层神经网络——激活函数去线性化
  9. 本周三、四两场直播丨达梦 vs. Oracle,从快速入门到性能分析优化
  10. 参会指南丨3分钟带你玩转2020数据技术嘉年华!