# 构建 Spark
* [构建 Apache Spark](#构建-apache-spark)
* [Apache Maven](#apache-maven)
* [设置 Maven 的内存使用](#设置-maven-的内存使用)
* [build/mvn](#buildmvn)
* [构建一个可运行的 Distribution 版本](#构建一个可运行的-distribution-版本)
* [指定 Hadoop 版本并启用 YARN](#指定-hadoop-版本并启用-yarn)
* [使用 Hive 和 JDBC 支持构建](#使用-hive-和-jdbc-支持构建)
* [打包没有 Hadoop 依赖关系的 YARN](#打包没有-hadoop-依赖关系的-yarn)
* [使用 Mesos 构建](#使用-mesos-构建)
* [使用 Scala 2.10 构建](#使用-scala-210-构建)
* [单独构建子模块](#单独构建子模块)
* [Continuous Compilation(连续编译)](#continuous-compilation连续编译)
* [使用 SBT 构建](#使用-sbt-构建)
* [加速编译](#加速编译)
* [加密文件系统](#加密文件系统)
* [IntelliJ IDEA 或 Eclipse](#intellij-idea-或-eclipse)
* [运行测试](#运行测试)
* [使用 SBT 测试](#使用-sbt-测试)
* [运行独立测试](#运行独立测试)
* [PySpark pip 可安装](#pyspark-pip-可安装)
* [使用 Maven 进行 PySpark 测试](#使用-maven-进行-pyspark-测试)
* [运行 R 测试](#运行-r-测试)
* [运行基于 Docker 的集成测试套装](#运行基于-docker-的集成测试套装)
# 构建 Apache Spark
## Apache Maven
基于 Maven 的构建是 Apache Spark 的参考构建。构建 Spark 需要 Maven 3.3.9 或者更高版本和 Java 8+。请注意,Spark 2.2.0 对于 Java 7 的支持已经删除了。
### 设置 Maven 的内存使用
您需要通过设置 `MAVEN_OPTS` 将 Maven 配置为比通常使用更多的内存:
```
export MAVEN_OPTS="-Xmx2g -XX:ReservedCodeCacheSize=512m"
```
(`ReservedCodeCacheSize` 设置是可选的,但是建议使用。) 如果您不讲这些参数加入到 `MAVEN_OPTS` 中,则可能会看到以下错误和警告:
```
[INFO] Compiling 203 Scala sources and 9 Java sources to /Users/me/Development/spark/core/target/scala-2.11/classes...
[ERROR] Java heap space -> [Help 1]
```
您可以通过如前所述设置 `MAVEN_OPTS` 变量来解决这些问题。
**注意:**
* 如果使用 `build/mvn` 但是没有设置 `MAVEN_OPTS`,那么脚本会自动地将以上选项添加到 `MAVEN_OPTS` 环境变量。
* 即使不适用 `build/mvn`,Spark 构建的 `test` 阶段也会自动将这些选项加入到 `MAVEN_OPTS` 中。
### build/mvn
Spark 现在与一个独立的 Maven 安装包封装到了一起,以便从位于 `build/` 目录下的源代码构建和部署 Spark。该脚本将自动下载并设置所有必要的构建需求([Maven](https://maven.apache.org/),[Scala](http://www.scala-lang.org/) 和 [Zinc](https://github.com/typesafehub/zinc))到本身的 `build/` 目录下。其尊重任何已经存在的 `mvn` 二进制文件,但是将会 pull down 其自己的 Scala 和 Zinc 的副本,不管是否满足适当的版本需求。`build/mvn` 的执行作为传递到 `mvn` 的调用,允许从以前的构建方法轻松转换。例如,可以像下边这样构建 Spark 的版本:
```
./build/mvn -DskipTests clean package
```
其他的构建例子可以在下边找到。
## 构建一个可运行的 Distribution 版本
想要创建一个像 [Spark 下载](http://spark.apache.org/downloads.html) 页面中的 Spark distribution 版本,并且使其能够运行,请使用项目 root 目录下的 `./dev/make-distribution.sh`。它可以使用 Maven 的配置文件等等进行配置,如直接使用 Maven 构建。例如:
```
./dev/make-distribution.sh --name custom-spark --pip --r --tgz -Psparkr -Phadoop-2.7 -Phive -Phive-thriftserver -Pmesos -Pyarn
```
这将构建 Spark distribution 以及 Python pip 和 R 包。有关使用情况的更多信息,请运行 `./dev/make-distribution.sh --help`
## 指定 Hadoop 版本并启用 YARN
您可以通过 `hadoop.version` 属性指定要编译的 Hadoop 的确切版本。如果未指定,Spark 将默认构建为 Hadoop 2.6.X。
您可以启用 `yarn` 配置文件,如果与 `hadoop.version` 不同的话,可以选择设置 `yarn.version` 属性。
示例:
```
# Apache Hadoop 2.6.X
./build/mvn -Pyarn -DskipTests clean package
# Apache Hadoop 2.7.X and later
./build/mvn -Pyarn -Phadoop-2.7 -Dhadoop.version=2.7.3 -DskipTests clean package
```
## 使用 Hive 和 JDBC 支持构建
要启用 Spark SQL 及其 JDBC server 和 CLI 的 Hive 集成,将 `-Phive` 和 `Phive-thriftserver` 配置文件添加到现有的构建选项中。默认情况下,Spark 将使用 Hive 1.2.1 绑定构建。
```
# With Hive 1.2.1 support
./build/mvn -Pyarn -Phive -Phive-thriftserver -DskipTests clean package
```
## 打包没有 Hadoop 依赖关系的 YARN
默认情况下,由 `mvn package` 生成的 assembly directory(组件目录)将包含所有的Spark 依赖,包括 Hadoop 及其一些生态系统项目。在 YARN 部署中,导致这些的多个版本显示在执行器 classpaths 上: Spark 组件的打包的版本和每个节点上的版本,包含在 `yarn.application.classpath` 中。`hadoop-provided` 配置文件构建了不包括 Hadoop 生态系统项目的组件,就像 ZooKeeper 和 Hadoop 本身。
## 使用 Mesos 构建
```
./build/mvn -Pmesos -DskipTests clean package
```
## 使用 Scala 2.10 构建
要使用 Scala 2.10 编译的 Spark 软件包,请使用 `-Dscala-2.10` 属性:
```
./dev/change-scala-version.sh 2.10
./build/mvn -Pyarn -Dscala-2.10 -DskipTests clean package
```
请注意,Scala 2.10 的支持已经不再适用于 Spark 2.1.0,并且可能在 Spark 2.2.0 中被删除。
## 单独构建子模块
可以使用 `mvn -pl` 选项来构建 Spark 的子模块。
例如,您可以使用下面打代码来构建 Spark Streaming 模块:
```
./build/mvn -pl :spark-streaming_2.11 clean install
```
其中 `spark-streaming_2.11` 是在 `streaming/pom.xml` 文件中定义的 `artifactId`。
## Continuous Compilation(连续编译)
我们使用支持增量和连续编译的 scala-maven-plugin 插件。例如:
```
./build/mvn scala:cc
```
这里应该运行连续编译(即等待更改)。然而这并没有得到广泛的测试。有几个需要注意的事情:
* 它只扫描路径 `src/main` 和 `src/test`(查看 [docs](http://scala-tools.org/mvnsites/maven-scala-plugin/usage_cc.html)),所以其只对含有该结构的某些子模块起作用。
* 您通常需要在工程的根目录运行 `mvn install` 在编译某些特定子模块时。这是因为依赖于其他子模块的子模块需要通过 `spark-parent` 模块实现。
因此,运行 `core` 子模块的连续编译总流程会像下边这样:
```
$ ./build/mvn install
$ cd core
$ ../build/mvn scala:cc
```
## 使用 SBT 构建
Maven 是推荐用于打包 Spark 的官方构建工具,是 _build of reference_。但是 SBT 支持日常开发,因为它可以提供更快的迭代编译。更多高级的开发者可能希望使用 SBT。SBT 构建是从 Maven POM 文件导出的,因此也是相同的 Maven 配置文件和变量可以设置来控制 SBT 构建。例如:
```
./build/sbt package
```
为了避免在每次需要重新编译时启动 sbt 的开销,可以启动 sbt 在交互模式下运行 `build/sbt`,然后在命令中运行所有构建命令提示。
## 加速编译
经常编译 Spark 的开发人员可能希望加快编译速度; 例如通过使用 Zinc(对于使用 Maven 构建的开发人员)或避免重新编译组件 JAR(对于使用 SBT 构建的开发人员)。有关如何执行此操作的更多信息,请参阅 [有用的开发工具页面](http://spark.apache.org/developer-tools.html#reducing-build-times)。
## 加密文件系统
当在加密文件系统上构建时(例如,如果您的 home 目录是加密的),则 Spark 构建可能会失败,并导致 “Filename too long” 错误。作为解决方法,在项目 `pom.xml` 中的 `scala-maven-plugin` 的配置参数中添加以下内容:
```
<arg>-Xmax-classfile-name</arg>
<arg>128</arg>
```
在 `project/SparkBuild.scala` 添加:
```
scalacOptions in Compile ++= Seq("-Xmax-classfile-name", "128"),
```
到 `sharedSettings` val。如果您不确定添加这些行的位置,请参阅 [this PR](https://github.com/apache/spark/pull/2883/files)。
## IntelliJ IDEA 或 Eclipse
有关设置 IntelliJ IDEA 或 Eclipse 用于 Spark 开发和故障排除的帮助,请参阅 [有用的开发工具页面](http://spark.apache.org/developer-tools.html)。
# 运行测试
默认情况下通过 [ScalaTest Maven plugin](http://www.scalatest.org/user_guide/using_the_scalatest_maven_plugin) 进行测试。请注意,测试不应该以 root 用户或者 admin 用户运行。
以下是运行测试的命令示例:
```
./build/mvn test
```
## 使用 SBT 测试
以下是运行测试的命令示例:
```
./build/sbt test
```
## 运行独立测试
有关如何运行独立测试的信息,请参阅 [有用的开发工具页面](http://spark.apache.org/developer-tools.html#running-individual-tests)。
## PySpark pip 可安装
如果您正在构建 Spark 以在 Python 环境中使用,并且希望对其进行 pip 安装,那么您将首先需要如上所述构建 Spark JARs。然后,您可以构建适合于 setup.py 和 pip 可安装软件包的 sdist 软件包。
```
cd python; python setup.py sdist
```
**注意:** 由于打包要求,您无法直接从 Python 目录中进行 pip 安装,而是必须首先按照上述方式构建 sdist 包。
或者,您还可以使用 –pip 选项运行 make-distribution。
## 使用 Maven 进行 PySpark 测试
如果您正在构建 PySpark 并希望运行 PySpark 测试,则需要使用 Hive 支持构建 Spark。
```
./build/mvn -DskipTests clean package -Phive
./python/run-tests
```
run-tests 脚本也可以限于特定的 Python 版本或者特定的模块。
```
./python/run-tests --python-executables=python --modules=pyspark-sql
```
**注意:** 您还可以使用 sbt 构建来运行 Python 测试,只要您使用 Hive 支持构建 Spark。
## 运行 R 测试
要运行 SparkR 测试,您需要首先安装 [knitr](https://cran.r-project.org/package=knitr),[rmarkdown](https://cran.r-project.org/package=rmarkdown),[testthat](https://cran.r-project.org/package=testthat),[e1071](https://cran.r-project.org/package=e1071) and [survival](https://cran.r-project.org/package=survival) 包:
```
R -e "install.packages(c('knitr', 'rmarkdown', 'testthat', 'e1071', 'survival'), repos='http://cran.us.r-project.org')"
```
您可以使用以下命令只运行 SparkR 测试:
```
./R/run-tests.sh
```
## 运行基于 Docker 的集成测试套装
为了运行 Docker 集成测试,你必须在你的 box 上安装 `docker` engine(引擎)。有关安装说明,请参见 [Docker 站点](https://docs.docker.com/engine/installation/)。一旦安装,如果还没有运行 Docker 服务,`docker` service 就需要启动。在 Linux 上,这可以通过 `sudo service docker start` 来完成。
```
./build/mvn install -DskipTests
./build/mvn test -Pdocker-integration-tests -pl :spark-docker-integration-tests_2.11
```
或者
```
./build/sbt docker-integration-tests/test
```
- Spark 概述
- 编程指南
- 快速入门
- Spark 编程指南
- 构建在 Spark 之上的模块
- Spark Streaming 编程指南
- Spark SQL, DataFrames and Datasets Guide
- MLlib
- GraphX Programming Guide
- API 文档
- 部署指南
- 集群模式概述
- Submitting Applications
- 部署模式
- Spark Standalone Mode
- 在 Mesos 上运行 Spark
- Running Spark on YARN
- 其它
- 更多
- Spark 配置
- Monitoring and Instrumentation
- Tuning Spark
- 作业调度
- Spark 安全
- 硬件配置
- Accessing OpenStack Swift from Spark
- 构建 Spark
- 其它
- 外部资源
- Spark RDD(Resilient Distributed Datasets)论文
- 翻译进度