Spark名词解释

来源:互联网 发布:js中增删数组元素 编辑:程序博客网 时间:2024/04/28 01:17

名词解释:

1. Standalone模式下存在的角色。

【Client】:客户端进程,负责提交作业到Master。

【Master】:Standalone模式中主控节点,负责接收Client提交的作业,管理Worker,并命令Worker启动Driver和Executor。

Master.scala

private def schedule(): Unit = {    if (state != RecoveryState.ALIVE) { return }    // Drivers take strict precedence over executors    val shuffledWorkers = Random.shuffle(workers) // Randomization helps balance drivers    for (worker <- shuffledWorkers if worker.state == WorkerState.ALIVE) {      for (driver <- waitingDrivers) {        if (worker.memoryFree >= driver.desc.mem && worker.coresFree >= driver.desc.cores) {          launchDriver(worker, driver)//1.先启动Driver          waitingDrivers -= driver        }      }    }    startExecutorsOnWorkers()//2.启动Workers上面的Executors  }

【Worker】:Standalone模式中slave节点上的守护进程,负责管理本节点的资源,定期向Master汇报心跳,接收Master的命令,启动Driver和Executor。

【Driver】: 一个Spark作业运行时包括一个Driver进程,也是作业的主进程,负责作业的解析、生成Stage并调度Task到Executor上。包括DAGScheduler,TaskScheduler。

【Executor】:即真正执行作业的地方,一个集群一般包含多个Executor,每个Executor接收Driver的命令Launch Task,一个Executor可以执行一到多个Task。

多个Task。

2.作业相关的名词解释

【Stage】:一个Spark作业一般包含一到多个Stage。

【Task】:一个Stage包含一到多个Task,通过多个Task实现并行运行的功能。

【DAGScheduler】: 实现将Spark作业分解成一到多个Stage,每个Stage根据RDD的Partition个数决定Task的个数,然后生成相应的Task set放到TaskScheduler中。

【TaskScheduler】:实现Task分配到Executor上执行。

0 0
原创粉丝点击