Spark 安装(集群模式)

Spark 安装(集群模式)

实际生产环境一般不会用本地模式搭建Spark。生产环境一般都是集群模式。下面就给出了安装集群模式的步骤。

运行环境

  • 操作系统 ------ Spark一般都是部署在Linux上,这里用的是Ubuntu 14.04及以上版本,也可以使用CentOS,RedHat等Linux系统,本教程用的是 Ubuntu 系统。
  • Spark ------ Apache Spark 2.X

因为是集群模式,所以需要多个物理节点,可以使用阿里云、腾讯云。也可以在自己机器搭建虚拟机集群。

在主节点安装Spark

安装前准备

修改host文件

编辑 hosts 文件,并增加下面记录

复制代码
sudo nano /etc/hostsMASTER-IP masterSLAVE01-IP slave01SLAVE02-IP slave02

注意把 MASTER-IP、SLAVE01-IP、SLAVE02-IP 替换成你自己机器的IP地址。

安装Java 7
复制代码
sudo apt-get install python-software-propertiessudo add-apt-repository ppa:webupd8team/javasudo apt-get updatesudo apt-get install oracle-java7-installer
安装Scala
复制代码
sudo apt-get install scala
配置SSH

安装 openssh-serveropenssh-client

生成密钥
复制代码
ssh-keygen -t rsa -P ""
配置无密码SSH

把 master 节点 .ssh/id_rsa.pub复制到 .ssh/authorized_keys。其他 Slave 节点跟 Master 一样的操作过程。

用SSH连接测试

用SSH命令连接到其他任意主机,看看是否需要密码。如果没提示输入密码,则免密码连接配置成功。

复制代码
ssh slave01ssh slave02

安装Spark

下载Spark

可以从Spark官网下载最新版本

http://spark.apache.org/downloads.html

解压tar包
复制代码
tar xzf spark-2.0.0-bin-hadoop2.6.tgz
安装配置

在用户 home 目录下编辑 .bashrc,并新增环境变量。

复制代码
export JAVA_HOME=<path-of-Java-installation> (eg: /usr/lib/jvm/java-7-oracle/)export SPARK_HOME=<path-to-the-root-of-your-spark-installation> (eg: /home/dataflair/spark-2.0.0-bin-hadoop2.6/)export PATH=$PATH:$SPARK_HOME/bin

让环境变量生效
source .bashrc

编辑 spark-env.sh
cd $SPARK_HOME/conf/

在该目录下并没有 spark-env.sh 文件,得从 spark-env.sh.tmplate 复制一个文件,文件名修改为 spark-env.sh
cp spark-env.sh.template spark-env.sh

spark-env.sh 新增下面的环境变量

复制代码
export JAVA_HOME=<path-of-Java-installation> (eg: /usr/lib/jvm/java-7-oracle/)export SPARK_WORKER_CORES=8

新增 Slave 节点

$SPARK_HOME/conf/ 目录下创建 slaves 配置文件,并在该文件写入两个节点的主机名:

复制代码
slave01slave02

在 Slave 节点安装 Spark

安装前准备

  • 编辑hosts文件
    • 安装java 7
    • 安装Scala

这些步骤跟Master的一样

把Spark安装包拷贝到所有Slave节点

先压缩安装包
tar czf spark.tar.gz spark-2.0.0-bin-hadoop2.6

把压缩好的安装包拷贝到 Slave 节点

复制代码
scp spark.tar.gz slave01:~scp spark.tar.gz slave02:~

注意:这些命令在 Master 节点执行注意:这些命令在 Master 节点执行

在Slave节点解压安装包

复制代码
tar xzf spark.tar.gz

注意:该命令在Slave节点执行

到这里,Spark 已经在 Master 和 Slave 节点安装并配置完成。可以启动 Spark 集群了。

启动Spark集群

启动Spark服务

复制代码
sbin/start-all.sh

注意:该命令在Master节点执行

检查服务是否启动成功

检查Master节点进程

复制代码
$jpsMaster

检查Slave节点进程

复制代码
$jpsWorker

Spark Web UI

spark Master节点UI界面地址和端口
http://MASTER-IP:8080/

从这里可以看到 Spark 的 Slave 节点信息,执行中的 application,集群资源等信息

spark 应用程序UI界面地址和端口
http://MASTER-IP:4040/

停止Spark集群

可以在Master执行下面命令停止Spark集群
sbin/stop-all.sh

相关推荐
明达智控技术19 分钟前
MR30分布式I/O在面机装备中的应用
分布式·物联网·自动化
TDengine (老段)25 分钟前
TDengine 选择函数 First 用户手册
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
沧海一粟青草喂马1 小时前
抖音批量上传视频怎么弄?抖音矩阵账号管理的专业指南
大数据·人工智能·矩阵
理智的煎蛋2 小时前
CentOS/Ubuntu安装显卡驱动与GPU压力测试
大数据·人工智能·ubuntu·centos·gpu算力
赵孝正2 小时前
GitLab 分支管理与 Push 问题全解析
大数据·elasticsearch·gitlab
JAVA学习通3 小时前
【RabbitMQ】---RabbitMQ 工作流程和 web 界面介绍
分布式·rabbitmq
嘉禾望岗5033 小时前
Yarn介绍与HA搭建
大数据·hadoop·yarn
小麦矩阵系统永久免费3 小时前
小麦矩阵系统:让短视频分发实现抖音快手小红书全覆盖
大数据·人工智能·矩阵
IT研究室3 小时前
大数据毕业设计选题推荐-基于大数据的国家药品采集药品数据可视化分析系统-Spark-Hadoop-Bigdata
大数据·hadoop·信息可视化·spark·毕业设计·数据可视化·bigdata
安卓开发者4 小时前
鸿蒙NEXT应用数据持久化全面解析:从用户首选项到分布式数据库
数据库·分布式·harmonyos