Spark学习笔记5:Spark集群架构

  Spark的一大好处就是能够经过增长机器数量并使用集群模式运行,来扩展计算能力。Spark能够在各类各样的集群管理器(Hadoop YARN , Apache Mesos , 还有Spark自带的独立集群管理器)上运行,因此Spark应用既可以适应专用集群,又能用于共享的云计算环境。java

  • Spark运行时架构

Spark在分布式环境中的架构以下图:python

  在分布式环境下,Spark集群采用的是主/从结构。在Spark集群,驱动器节点负责中央协调,调度各个分布式工做节点。执行器节点是工做节点,做为独立的Java进行运行,能够和大量的执行器节点进行通讯,做为独立的Java进程运行。驱动器节点和全部的执行器节点一块儿被称为一个Spark应用。mysql

  Spark应用经过一个叫作集群管理器的外部服务在集群上的机器上启动。Spark自动的集群管理器称为独立集群管理器。Spark也能运行在Hadoop YARN和Apache Mesos两大开源集群管理器上。sql

  详细说明驱动器节点和执行器节点的做用:apache

一、驱动器节点缓存

Spark驱动器是执行程序中main()方法的进程。它执行用户编写的用来建立SparkContext ,建立RDD,以及进行RDD转化操做和行动操做的代码。架构

驱动器进程在Spark应用中有如下两个职责:app

  • 把用户程序转为任务

Spark驱动器程序负责把用户程序转为多个物理执行的单元,这些单元称为任务。任务是Spark中最小的工做单元,用户程序一般要启动成百上千的独立任务。分布式

  • 为执行器节点调度任务

Spark驱动器在各执行器进程间协调任务的调度,驱动器进程对应用中全部的执行器节点有完整的记录。每一个执行器节点表明一个可以处理任务和存储RDD数据的进程。oop

二、执行器节点

Spark执行器节点是一种工做进程,负责在Spark做业中运行任务,任务间相互独立。执行器节点在Spark应用启动时启动,伴随着整个Spark应用的生命周期而存在。

执行器节点负责运行组成Spark应用的任务,并将结果返回给驱动器进程。

执行器节点经过自身的块管理器为用户程序中要求缓存的RDD提供内存式存储。

 

  • spark-submit部署应用

使用Spark提供的统一脚本spark-submit将应用提交到集群管理器上。

spark-submit提供了各类选项能够控制应用每次运行的各项细节。这些选项分为两类:第一类是调度信息,好比你但愿为做业申请的资源量。第二类是应用的运行时依赖,好比须要部署到全部工做节点的库和文件。

spark-submit的通常格式:

  bin/spark-submit [options]  <app jar | python file>  [app options]

[options]是要传给spark-submit的标记列表,运行spark-submit --help 能够列出全部能够接收的标记。

<app jar | python file>表示包含应用入口的JAR包或Python脚本。

[app options]是传给应用的选项。

spark-submit一些经常使用的标记以下:

 

  • 使用Maven依赖
<properties>
        <scala.version>2.10.4</scala.version>
        <spark.version>1.6.3</spark.version>
        <hadoop.version>2.6.0</hadoop.version>
    </properties>

    <dependencies>
        <!--         scala        -->
        <dependency>
            <groupId>org.scala-lang</groupId>
            <artifactId>scala-library</artifactId>
            <version>${scala.version}</version>
        </dependency>
        <dependency>
            <groupId>org.scala-lang</groupId>
            <artifactId>scala-compiler</artifactId>
            <version>${scala.version}</version>
        </dependency>
        <dependency>
            <groupId>org.scala-lang</groupId>
            <artifactId>scala-reflect</artifactId>
            <version>${scala.version}</version>
        </dependency>

        <!--         spark        -->
        <dependency>
            <groupId>org.apache.spark</groupId>
            <artifactId>spark-core_2.10</artifactId>
            <version>${spark.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.spark</groupId>
            <artifactId>spark-mllib_2.10</artifactId>
            <version>${spark.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.spark</groupId>
            <artifactId>spark-sql_2.10</artifactId>
            <version>${spark.version}</version>
        </dependency>

        <!--         hive        -->
        <dependency>
            <groupId>org.apache.spark</groupId>
            <artifactId>spark-hive_2.10</artifactId>
            <version>${spark.version}</version>
        </dependency>

        <!--       hadoop      -->
        <dependency>
            <groupId>org.apache.hadoop</groupId>
            <artifactId>hadoop-common</artifactId>
            <version>${hadoop.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.hadoop</groupId>
            <artifactId>hadoop-client</artifactId>
            <version>${hadoop.version}</version>
        </dependency>

       <!--    JDBC     -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.35</version>
        </dependency>
    </dependencies>
  •   Spark应用内与应用间调度

在调度多用户集群时,Spark主要依赖集群管理器来在Saprk应用间共享资源。Spark内部的公平调度器会让长期运行的应用定义调度任务的优先级队列。

相关文章
相关标签/搜索