Yarn分布式部署模式

独立部署(Standalone)模式由Spark自身提供计算资源,无需其他框架提供资源。这种方式降低了和其他第三方资源框架的耦合性,独立性非常强。但是你也要记住,Spark主要是计算框架,而不是资源调度框架,所以本身提供的资源调度并不是它的强项,所以还是和其他专业的资源调度框架集成会更靠谱一些。

1、安装

(1)集群规划

hadoop101

hadoop102

hadoop103

Spark

NodeManager

ResourceManager

NodeManager

NameNode

NodeManager

DataNode

DataNode

DataNode

(2)安装

直接解压对应的包即可

tar -zxvf spark-3.0.0-bin-hadoop3.2.tgz -C /opt/module

2、修改配置文件

(1)修改hadoop配置文件/opt/module/hadoop/etc/hadoop/yarn-site.xml, 并分发

<!--是否启动一个线程检查每个任务正使用的物理内存量,如果任务超出分配值,则直接将其杀掉,默认 是 true -->
<property>
<name>yarn.nodemanager.pmem-check-enabled</name> 
<value>false</value>
</property>
<!--是否启动一个线程检查每个任务正使用的虚拟内存量,如果任务超出分配值,则直接将其杀掉,默认 是 true --> 
<property>
<name>yarn.nodemanager.vmem-check-enabled</name> 
<value>false</value>
</property>

(2)修改conf/spark-env.sh,添加JAVA_HOME和YARN_CONF_DIR配置

export JAVA_HOME=/opt/module/jdk1.8.0_144
YARN_CONF_DIR=/opt/module/hadoop-2.7.2/etc/hadoop

3、配置历史服务器

(1)修改spark-defaults.conf.template文件名为spark-defaults.conf

mv spark-defaults.conf.template spark-defaults.conf

(2)修改spark-default.conf文件,配置日志存储路径,设置历史服务日志的访问信息,关联yarn和spark

spark.eventLog.enabled  true
spark.eventLog.dir  hdfs://hadoop101:9000/directory
spark.yarn.historyServer.address=hadoop101:18080 
spark.history.ui.port=18080

(3)修改spark-env.sh文件,添加日志配置

export SPARK_HISTORY_OPTS=" 
-Dspark.history.ui.port=18080 
-Dspark.history.fs.logDirectory=hdfs://hadoop101:9000/directory 
-Dspark.history.retainedApplications=30"

(4)启动历史服务

sbin/start-history-server.sh

4、启动HDFS以及Yarn集群

hdfs的namenode在hadoop101上,所以需要到hadoop101启动

sbin/start-dfs.sh

yarn的resourcemanager设置在hadoop102上,所以需要到hadoop102上启动

sbin/start-yarn.sh

5、提交测试应用以及查看历史页面

(1)提交应用的模式现在为cluster模式,此时控制台不会打印结果

bin/spark-submit  --class org.apache.spark.examples.SparkPi --master yarn  --deploy-mode cluster ./examples/jars/spark-examples_2.12-3.0.1.jar  10

(2)提交应用的模式现在为client模式,此时控制台会打印程序的输出结果

bin/spark-submit  --class org.apache.spark.examples.SparkPi --master yarn  --deploy-mode client ./examples/jars/spark-examples_2.12-3.0.1.jar  10

6、查看历史日志

http://hadoop102:8088

访问该页面后,点击对应application的history就可以查看相关的运行过程。