注: 1. 本文链接中,包含[]的为已翻译的文档链接,不包含的为官方文档链接。 2. 涉及到编程语言的部分,以翻译Scala的部分为主

  • Spark概述
  • 下载
  • 运行示例和Shell
  • 在集群上运行
  • 从这里开始

Spark概述

Apache Spark是一个快速的,通用的集群计算系统。在Java,Scala,Python和R语言中提供了高层API,并提供一个支持一般图形计算的优化引擎。Spark支持一个丰富的高层工具集,包括Spark SQL用于SQL和结构化数据处理,MLLib用于机器学习,GraphX用于图处理和Spark Streaming。

下载

从官网下载页面获取Spark。本文档适用于Spark 2.1.0版本。Spark为使用HDFS和YARN而需要用到Hadoop客户端库。下载包是为适配主流Hadoop版本预先打包好的。用户还可以下载”Hadoop free”二进制文件,然后通过配置Spark的classpath在任意版本的Hadoop中运行Spark。Scala和Java用户可以使用maven cooridnates在项目中包含Spark。将来Python用户也可以从PyPI中安装Spark。

如果想要从源码编译Spark,访问构建Spark。

Spark可以在Windows和类UNIX系统(如Linux,Mac OS)上运行。Spark很容易在一台机器上本地运行——你需要做的就是在系统PATH上安装了Java,或者在JAVA_HOME环境变量中指定了Java的安装路径。

Spark可以运行在Java 7+,Python 2.6+/3.4+,R 3.1+环境上。对于Scala API,Spark 2.1.0使用的是Scala 2.11。你需要使用一个可兼容的Scala版本(2.11.x)。

请注意,从Spark 2.0.0开始,对Java 7和Python 2.6的支持已弃用,从Spark 2.1.0开始,对Scala 2.10和Hadoop 2.6之前版本的支持已弃用,在Spark 2.2.0时可能会被删除。

运行示例和Shell

Spark自带几个示例程序。Scala,Java,Python和R语言的示例在 examples/src/main 目录下。要运行Java或者Scala示例程序,在Spark的根目录中使用bin/run-example <class> [params](在后台,将调用更通用的spark-submit脚本来启动应用程序)。例如:

./bin/run-example SparkPi 10

也可以使用一个修改版的Scala Shell以交互方式运行Spark。这是一种学习框架非常好的方式。

./bin/spark-shell –master local[2]

其中--master选项指定了分布式集群的master URL,local以单线程在本地运行,local[N]以N个线程在本地运行。你应该首先使用local来进行测试。完整的选项列表,可使用--help选项来运行Spark。

Spark也提供了Python API。要在Python解释器中以交互方式运行Spark,使用bin/pyspark:

./bin/pyspark –master local[2]

Spark也提供了Python的示例应用程序,例如,

./bin/spark-submit examples/src/main/python/pi.py 10

Spark从1.4版本开始就提供了一个实验的R API(只包含DataFrames API)。要在R语言解释器中交互式地运行Spark,使用bin/sparkR:

./bin/sparkR –master local[2]

Spark也提供了R语言的示例应用程序,例如,

./bin/spark-submit examples/src/main/r/dataframe.R

在集群上运行

Spark集群模式概述解释了在集群上运行Spark的关键概念。Spark可以独立运行,或者在多个现有的集群管理器上运行。目前提供了集中部署选项:

  • Standalone Deploy Mode:在私有集群上部署Spark最简单的方法
  • Apache Mesos
  • Hadoop YARN

从这里开始

编程指南:

  • [Quick Start]:Spark的快速介绍,从这开始吧!
  • [Spark Programming Guide]:Spark在所有支持语言(Scala,Java,Python,R)中的详细概述。
  • 构建在Spark上的模块:
  • Spark Streaming:处理实时数据流
  • Spark SQL, Datasets, and DataFrames:支持结构化数据和关系查询
  • MLlib:内置的机器学习库
  • GraphX:Spark用于图形处理的新API

API文档:

  • Spark Scala API (Scaladoc)
  • Spark Java API (Javadoc)
  • Spark Python API (Sphinx)
  • Spark R API (Roxygen2)

部署指南:

  • 集群概述:在集群运行时的概念和组件概述
  • 提交应用程序:打包和部署应用程序
  • 部署模式:
  • Amazon EC2:让你在5分钟之内在EC2上启动集群的脚本
  • Standalone Deploy Mode:不使用第三方集群管理器的情况下快速启动独立集群
  • Mesos:使用Apache Mesos部署一个私有集群
  • YARN:在Hadoop NextGen (YARN)上部署Spark

其它文档

  • 配置:通过配置系统定制Spark
  • 监控:跟踪你的应用程序的行为
  • 优化指南:优化性能和内存使用的最佳实践
  • 任务调度:在应用程序内和跨应用程序调度资源
  • 安全性:Spark的安全性支持
  • 硬件配置:对集群硬件配置的建议
  • 与其它存储系统集成
  • OpenStack Swift
  • 构建Spark:使用Maven系统来构建Spark
  • 给Spark做贡献
  • 第三方项目:相关的第三方Spark项目

外部资源

  • Spark主页
  • Spark社区:资源,包括一些当地的聚会
  • StackOverflow tag apache-spark
  • 邮件列表:可以在这里问Spark的问题
  • AMP Camps:在加州大学伯克利分校的一系列训练营,关于Spark,Spark Streaming,Mesos以及更多内容的特色演讲和练习。视频,幻灯片和练习可以在网上免费获取。
  • 代码示例:可以在Spark(Scala, Java, Python, R)的examples子文件夹中获取更多示例。