Spark基础学习笔记04:搭建Spark伪分布式环境

零、本讲学习目标

  1. 学会搭建Spark伪分布式环境
  2. 学会启动Spark Shell进行交互式操作
  3. 学会使用Spark WebUI查看运行状态

Spark单机伪分布式是在一台机器上既有Master,又有Worker进程。搭建Spark单机伪分布式环境可在Hadoop伪分布式的基础上进行搭建。

一、搭建伪分布式Hadoop

(一)登录ied虚拟机

  • 利用win7虚拟机上的FinalShell登录ied虚拟机

  • 本机远程桌面连接win7虚拟机【对外IP地址:192.168.177.116,私有IP地址:192.168.100】
    在这里插入图片描述

  • 虚拟机ied上已经安装了Spark单机版环境,单机版Spark不需要Hadoop,但是Spark伪分布式环境就需要建立在Hadoop伪分布式环境基础之上。

(二)配置免密登录

1、在ied虚拟机上生成密钥对

  • 执行ssh-keygen命令后,一直敲回车,生成节点的公钥和私钥,生成的文件id_rsa会自动放在/root/.ssh目录下,然后我们可以把公钥发往远程机器或本机。
    在这里插入图片描述

2、将生成的公钥发送到本机

  • 执行命令:ssh-copy-id root@ied
    在这里插入图片描述

3、验证虚拟机是否能免密登录本机

  • 执行命令:ssh ied,再执行命令:exit
    在这里插入图片描述

(三)下载与Spark版本匹配的Hadoop安装包

(四)上传Hadoop安装包

  • 将Hadoop安装包上传到虚拟机ied的/opt目录
    在这里插入图片描述
    在这里插入图片描述

(五)将Hadoop安装包解压到指定目录

  • 执行命令:tar -zxvf hadoop-2.7.7.tar.gz -C /usr/local
    在这里插入图片描述

(六)查看Hadoop目录

1、查看Hadoop安装目录

  • 执行命令:cd /usr/local/hadoop-2.7.7ll
    在这里插入图片描述

  • bin目录:命令脚本

  • etc/hadoop目录:存放hadoop的配置文件

  • lib目录:hadoop运行的依赖jar包

  • sbin目录:存放启动和关闭hadoop等命令

  • libexec目录:存放的也是hadoop命令,但一般不常用

  • 最常用的就是bin和etc目录

2、查看Hadoop配置目录

  • 勾出了Hadoop比较重要的配置文件
    在这里插入图片描述

3、查看sbin子目录

  • 勾出了启动与停止dfs和yarn服务的脚本文件
    在这里插入图片描述

(七)配置Hadoop实现伪分布式

1、修改环境配置文件 - hadoop-env.sh

  • 进入hadoop配置目录,执行命令:vim hadoop-env.sh
    在这里插入图片描述
    在这里插入图片描述
export JAVA_HOME=/usr/local/jdk1.8.0_231
export HADOOP_HOME=/usr/local/hadoop-2.7.7
export HADOOP_CONF_DIR=${HADOOP_HOME}/etc/hadoop
  • 存盘退出,然后执行source hadoop-env.sh,让配置立即生效
    在这里插入图片描述

2、修改核心配置文件 - core-site.xml

  • 执行命令:vim core-site.xml
    在这里插入图片描述
<configuration>
    <!--用来指定hdfs的老大,namenode的地址-->
    <property>
        <name>fs.defaultFS</name>
        <value>hdfs://ied:9000</value>
    </property>
    <!--用来指定hadoop运行时产生文件的存放目录-->
    <property>
        <name>hadoop.tmp.dir</name>
        <value>/usr/local/hadoop-2.7.7/tmp</value>
    </property>
</configuration>

3、修改分布式文件系统配置文件 - hdfs-site .xml

  • 执行命令:vim hdfs-site.xml
    在这里插入图片描述
<configuration>
    <!--指定hdfs保存数据副本数量,默认值是3-->
    <!--如果是伪分布模式,此值是1-->
    <property>
        <name>dfs.replication</name>
        <value>1</value>
    </property>
    <!--设置hdfs的操作权限,false表示任何用户都可以在hdfs上操作文件-->
    <property>
        <name>dfs.permissions</name>
        <value>false</value>
    </property>
</configuration>

4、修改MapReduce配置文件 - mapred-site.xml

  • 执行命令:cp mapred-site.xml.template mapred-site.xml,基于模板文件生成配置文件
    在这里插入图片描述

  • 执行命令:vim mapred-site.xml
    在这里插入图片描述

<configuration>
     <!--指定mapreduce运行在yarn上-->
     <property>
         <name>mapreduce.framework.name</name>
         <value>yarn</value>
     </property>
</configuration>
  • 说明:yarn是资源协调工具,将MapReduce交给它来管理,效率更高。

5、修改yarn配置文件 - yarn-site.xml

  • 执行命令:vim yarn-site.xml
    在这里插入图片描述
<configuration>
    <!--指定yarn的老大resoucemanager的地址-->
    <property>
        <name>yarn.resourcemanager.hostname</name>
        <value>ied</value>
    </property>
    <!--NodeManager获取数据的方式-->
    <property>
        <name>yarn.nodemanager.aux-services</name>
        <value>mapreduce_shuffle</value>
    </property>
</configuration>

6、配置hadoop的环境变量

  • 执行命令:vim /etc/profile
    在这里插入图片描述
export HADOOP_HOME=/usr/local/hadoop-2.7.7
export PATH=$HADOOP_HOME/bin:$HADOOP_HOME/sbin:$PATH
  • 存盘退出,执行命令source /etc/profile,让配置生效
    在这里插入图片描述

(八)格式化名称节点

  • 执行命令:hdfs namenode -format,格式化名称节点,形成可用的分布式文件系统HDFS
    在这里插入图片描述
  • 名称节点格式化成功信息
    在这里插入图片描述

(九)启动与关闭hadoop服务

1、启动Hadoop服务

  • 执行命令:start-dfs.sh,启动dfs服务 - 分布式存储
    在这里插入图片描述
  • 执行命令:start-yarn.sh,启动yarn服务 - 分布式计算
    在这里插入图片描述
  • 执行命令:jps,查看hadoop进程
    在这里插入图片描述

2、停止hadoop服务

  • 执行命令:stop-dfs.sh,停止dfs服务
    在这里插入图片描述
  • 执行命令:stop-yarn.sh,停止yarn服务
    在这里插入图片描述

二、搭建伪分布式Spark

  • 我们已经在单机版Spark基础上搭建了伪分布式Hadoop,下面通过Spark环境配置文件实现伪分布式Spark

(一)进入spark配置目录

  • 执行命令:cd $SPARK_HOME/conf
    在这里插入图片描述

(二)修改环境配置文件 - spark-env.sh

  • 基于环境配置文件模板生成环境配置文件
  • 执行命令:cp spark-env.sh.template spark-env.sh
    在这里插入图片描述
  • 执行命令:vim spark-env.sh
    在这里插入图片描述
  • 存盘退出,执行命令:source spark-env.sh,让环境配置生效
    在这里插入图片描述

(三)配置slaves文件

  • 执行命令:vim slaves(伪分布式,ied既是主节点,也是从节点)
    在这里插入图片描述

三、启动伪分布式Spark

(一)启动hadoop服务

  • 执行命令:start-dfs.sh
    在这里插入图片描述
  • 执行命令:start-yarn.sh
    在这里插入图片描述

(二)启动spark服务

  • 执行命令:start-master.sh,启动spark老大 - Master
    在这里插入图片描述

  • 执行命令:start-slaves.sh,启动spark小弟 - Worker
    在这里插入图片描述

  • 查看进程
    在这里插入图片描述

  • 执行命令:vim $SPARK_HOME/sbin/spark-config.sh,添加JAVA_HOME环境变量
    在这里插入图片描述

  • 存盘退出,执行命令:source $SPARK_HOME/sbin/spark-config.sh,让配置生效
    在这里插入图片描述

  • 此时,再执行命令:start-slaves.sh,启动spark小弟 - Worker
    在这里插入图片描述

四、交互式Spark Shell

  • /home/test.txt上传到HDFS的/input目录
    在这里插入图片描述

(一)scala版spark shell

  • 执行命令:spark-shell --master spark://ied:7077
    在这里插入图片描述

  • 演示词频统计
    在这里插入图片描述

  • scala>提示符后面执行:quit,退出scala版spark shell
    在这里插入图片描述

(二)python版spark shell

  • 执行命令:pyspark --master=local
    在这里插入图片描述

  • 演示词频统计
    在这里插入图片描述

  • >>>提示符后执行exit()函数退出python版spark shell
    在这里插入图片描述

五、访问Spark WebUI

(一)启动scala版spark shell

  • 执行命令:spark-shell --master spark://ied:7077
    在这里插入图片描述

(二)访问Spark WebUI

  • 访问http://ied:4040 - 注意端口号是4040
    在这里插入图片描述

1、关闭与禁用虚拟机ied的防火墙

  • 执行命令:systemctl stop firewalld
    在这里插入图片描述
  • 执行命令:systemctl disable firewalld
    在这里插入图片描述
  • 执行命令:systemctl status firewalld,查看防火墙状态
    在这里插入图片描述
  • 关闭宿主机win7防火墙
    在这里插入图片描述

2、配置宿主机win7的hosts文件

  • C:\Windows\System32\drivers\etc\hosts文件里添加一句IP与主机名映射:192.168.1.110 ied
    在这里插入图片描述

3、访问Spark WebUI

  • 访问http://ied:4040
    在这里插入图片描述
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

酒城译痴无心剑

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值