howtodown 发表于 2015-3-11 18:19:52

Spark入门一:Spark1.2伪分布式安装


问题导读


1.spark安装需要哪些环境?
2.如何配置spark?
3.如何启动spark?



static/image/hrline/4.gif




Spark1.2.0伪分布式安装
[*]JDK1.7.0_67
[*]Haddoop2.5.2(伪分布式安装)
[*]Scala2.11.4
[*]Spark1.2.0(伪分布式安装)

下载并配置Scala1. 下载Scala2.11.4

wget http://downloads.typesafe.com/scala/2.11.4/scala-2.11.4.tgz?_ga=1.10268349.906591.14198206932. 改名
mv scala-2.11.4.tgz?_ga=1.10268349.906591.1419820693 scala-2.11.4.tgz
3. 配置Scala的环境变量
vim /etc/profile
export SCALA_HOME=/home/hadoop/software/scala-2.11.4
export PATH=$SCALA_HOME/bin:$PATH

下载Spark1.2.0(与Hadoop2.4兼容版本)
1.下载Spark1.2.0与Hadoop2.4兼容版本
http://d3kbcqa49mib13.cloudfront.net/spark-1.2.0-bin-hadoop2.4.tgz
在本测试环境中,使用的是Hadoop2.5.2版本,测试发现,这个版本的Spark(2.4兼容版本)可以与Hadoop2.5.2兼容

2. 解压Spark安装包到如下目录

tar xzvf spark-1.2.0-bin-hadoop2.4.tgz
/home/hadoop/software/spark-1.2.0-bin-hadoop2.4配置Spark相关的环境变量1. vim /etc/profile,编辑完成后使用source /etc/profile使得变量生效
export SPARK_HOME=/home/hadoop/software/spark-1.2.0-bin-hadoop2.4
export HADOOP_CONF_DIR=$HADOOP_HOME/etc/hadoop
export YARN_CONF_DIR=$HADOOP_HOME/etc/hadoop
这些需要配置的环境变量很多,不过之前在安装JDK,Scala和Hadoop时,已经设置过了,具体需要配置哪些环境,可以看配置spark-env.sh的配置。为了保险期间,可以设置如下的环境变量(在/etc/profile和spark-env.sh同时配置)

[*]SCALA_HOME
[*]JAVA_HOME
[*]HADOOP_HOME
[*]SPARK_HOME
[*]YARN_CONF_DIR
2. 把spark-env.sh.template改为spark-env.sh

cp spark-env.sh.template spark-env.sh
3. 配置spark-env.sh

export SCALA_HOME=/home/hadoop/software/scala-2.11.4
export JAVA_HOME=/home/hadoop/software/jdk1.7.0_67
export SPARK_MASTER=localhost
export SPARK_LOCAL_IP=localhost
export HADOOP_HOME=/home/hadoop/software/hadoop-2.5.2
export SPARK_HOME=/home/hadoop/software/spark-1.2.0-bin-hadoop2.4
export SPARK_LIBARY_PATH=.:$JAVA_HOME/lib:$JAVA_HOME/jre/lib:$HADOOP_HOME/lib/native
export YARN_CONF_DIR=$HADOOP_HOME/etc/hadoop

启动Spark
1. 在Spark安装目录的sbin目录下执行./start-all.sh命令启动Spark

$SPARK_HOME/sbin/start-all.sh
2. 启动过程中报rsync错误,不过通过查看Java进程可以看到Spark已经启动




可见,启动Spark后,启动了两个Java进程Master和Worker

3. 访问http://localhost:8080,可以看到Spark Master的状态



4. 访问如下地址可以查看关于Spark相关的情况

[*]http://192.168.26.135:4040/jobs
[*]http://192.168.26.135:4040/stages/
[*]http://192.168.26.135:4040/storage/
[*]http://192.168.26.135:4040/environment/ (包含Spark Shell的类路径)



[*] http://192.168.26.135:4040/executors/
由下图可见,Spark Shell启动后,只有一个Executor,即driver





Spark Shell运行Word Count
1. 启动Spark Shell
bin/spark-shell
第一次启动过程中用了4分钟,并且系统卡住没反应,不过以后再启动Spark Shell则很快,快则1,2秒,慢则10几秒。Spark Shell启动后,Spark启动了一个进程SparkSubmit







2. 运行Spark Word Count

2.1 Spark Shell启动后,进行入scala命令行模式,此时,Spark已经默认给我们创建了一个SparkContext,sc,如:

scala> sc
res0: org.apache.spark.SparkContext = org.apache.spark.SparkContext@756cf002
2.2. 在Hadoop HDFS上创建一个文本文件,如:
hdfs dfs -cat /users/hadoop/wordcount/word.txt
内容是:




2.3 Spark读取HDFS上的文本文件word.txt

val file = sc.textFile("hdfs://hadoop.master:9000/users/hadoop/wordcount/word.txt")
这行语句的结果是创建了一个MappedRDD,即file的类型是MappedRDD,执行结果如下所示:



最后的<Console>:12,12指的是什么?不像是word.txt的字节数

2.3.0 题外话:
hdfs://hadoop.master:9000,这里的hadoop.master不能是localhost,因为telnet localhost 9000拒绝连接,如下图所示:





2.4. 执行如下操作
scala>val count = file.flatMap(line => line.split(" ")).map(word => (word, 1)).reduceByKey(_+_)
结果:



可见count是ShuffledRDD类型

2.5 统计结果

scala> count.collect()

查看Spark Master和Spark Worker的运行结果
通过访问http://192.168.26.135:8080/和http://192.168.26.135:8081/,可以查看Spark Master和Spark Worker的运行状态。结果发现,Master上Completed Applications依然为0,原因不清楚, Spark Master UI不显示Spark Shell提交的任务?








页: [1]
查看完整版本: Spark入门一:Spark1.2伪分布式安装