Spark集群搭建中的问题
参照《Spark实战高手之路》学习的,书籍电子版在51CTO网站 资料链接
Hadoop下载[链接](http://archive.apache.org/dist/hadoop/core/hadoop-1.2.1/)
JDK下载[链接](http://www.oracle.com/technetwork/java/javase/downloads/index.html)
1.安装好vmvare和Ubuntu虚拟机后,不能使用vim,出现Package has no installation candidate的问题。
解决方法:apt-get upgrade — apt-get install vim 有时候也要看看是否联网。
2.设置共享文件夹,参考别人的经验,安装vmware-tools 以及 设置共享文件夹
(1)在虚拟机系统没有运行的情况下,点击虚拟机工具栏的VM settings->options->Shared Folders,按照提示添加一个你要共享的windows下的文件夹。
(2)安装vmtools,vmtools安装成功后会看到目录/mnt/hgfs.如果没有该目录则可以手动建立(3)ubuntu终端下运行 sudo apt-get install open-vm-dkms
(4)进入目录:/etc/init.d,把”sudo mount -t vmhgfs .host:/ /mnt/hgfs”写到open-vm-tools文件的最后一行(需要root权限,可以用命令:sudo vi open-vm-tools)。
(5)在当前目录:/etc/init.d/运行,”sudo ./open-vm-tools restart”,运行成功后你会在目录:/mnt/hgfs下面看到你共享的文件夹
查看VMware tools 有没有安装成功,使用命令 lsmod 查看有没有vmhgfs这个,如果没有则重新安装。这个共享文件夹没有成功,后面有时间再说吧。
3.Hadoop启动与停止
start-all.sh: 启动所有的Hadoop守护进程。包括NameNode、 Secondary NameNode、DataNode、JobTracker、 TaskTrack 。
start-dfs.sh: 启动Hadoop HDFS守护进程NameNode SecondaryNameNode和DataNode。
hadoop-daemons.sh: start namenode 单独启动NameNode守护进程。
hadoop-daemons.sh: start datanode 单独启动DataNode守护进程
hadoop-daemons.sh: stop secondarynamenode 单独停止SecondaryNameNode守护进程。
stop-mapred.sh: 停止Hadoop MapReduce守护进程JobTracker和TaskTracker。
hadoop-daemons.sh: stop jobtracker 单独停止JobTracker守护进程
hadoop-daemons.sh: stop tasktracker 单独启动TaskTracker守护进程。
如果Hadoop集群是第一次启动,可以用start-all.sh。比较常用的启动方式是一个一个守护进程来启动,启动的步骤如下。
1.启动Hadoop的HDFS模块里的守护进程HDFS里面的守护进程启动也有顺序,即:
1)启动NameNode守护进程;> 2)启动DataNode守护进程; 3)启动SecondaryNameNode守护进程。
2.启动MapReduce模块里面的守护进程MapReduce的守护进程启动也是有顺序的,即:
1)启动 JobTracker守护进程; 2)启动TaskTracker守护进程。> 关闭的步骤正好相反,在这里就不描述了,读者可以自己试一下。
注意正常情况下,我们是不使用start-all.sh和stop-all.sh来启动和停止Hadoop集群的。这样出错了不好找原因。建议读者一个一个守护进程来启动,哪个启动失败就去看相应的log日志,这样就缩小了找错的范围。
4.Hadoop启动的时候遇到的错误,基本安装完后通过命令“jps”查看,但是只启动了jps,其他都不能正常启动,查看对应的log日志文件(vim查看),一个错误原因是配置文件写错了,改过后可以正常启动jobtracker、tasktracker;另一个原因就是目录访问权限不一致;
报错:
ERROR:org.apache.hadoop.hdfs.server.datanode.DataNode:All directories in dfs.data.dir are invalid warn。
WARN :org.apache.hadoop.hdfs.server.datanode.DataNode: Invalid directory in dfs.data.dir: Incorrect permission for /home/hadoop/dfs/data, expected: rwxr-xr-x, while actual: rwxrwxrwx。
使用命令修改目录访问权限。需要将777权限改为755权限才行。
可以参考博客。
5. namenode日志文件中出现
java.io.IOException:NameNode is not formatted
需要删除core-site.xml配置文件中配置的tmp目录下的所有的文件,停止Hadoop,再重新格式化命名,启动Hadoop。
进入Hadoop目录,运行以下程序:
rm -rf tmp/*
rm -rf /tmp/hadoop*
rm -rf hdfs/name/*
rm -rf hdfs/data/*
--然后重新格式化,启动
hadoop namenode -format
start-all.sh
6.搭建Spark时,启动错误:
Failed to find Spark assembly in /usr/lib/spark/spark-1.6.1/assembly/target/scala-2.10
错误原因是spark包下错了,应该下载prebuild包,Choose a package type 可以选择啊~~~
7.启动Spark后,开启spark-shell,出现错误:
java.lang.RuntimeException: java.lang.RuntimeException: The root scratch dir: /tmp/hive on HDFS should be writable. Current permissions are: rwx--x--x
需要修改访问/tmp文件权限
hadoop fs -chmod -R 777 /tmp
hadoop fs -ls /tmp
以上完成Spark集群搭建过程,后面每次开机使用,需要先启动Hadoop集群,再启动Spark集群。
--格式化
hadoop namenode -format
--启动Hadoop
start-all.sh
--使用jps查看是否启动成功,成功,再启动Spark,进入到spark的sbin目录
./start-all.sh
如果hadoop启动失败,可查看日志文件判别错误,一般都是因为每次使用“hadoop namenode -format”命令格式化文件系统时会出现一个新的namenodeId,搭建平台时自己往tmp中放了数据,所以需要删除,以防冲突,进入Hadoop文件所在目录(hadoop1.2.1目录)
执行:
rm -rf tmp/*
rm -rf /tmp/hadoop*
rm -rf hdfs/name/*
rm -rf hdfs/data/*
重新格式化,启动。检测是否成功参考资料中的第一章,第三步。
Spark集群搭建中的问题的更多相关文章
- Spark集群搭建简要
Spark集群搭建 1 Spark编译 1.1 下载源代码 git clone git://github.com/apache/spark.git -b branch-1.6 1.2 修改pom文件 ...
- Spark集群搭建简配+它到底有多快?【单挑纯C/CPP/HADOOP】
最近耳闻Spark风生水起,这两天利用休息时间研究了一下,果然还是给人不少惊喜.可惜,笔者不善JAVA,只有PYTHON和SCALA接口.花了不少时间从零开始认识PYTHON和SCALA,不少时间答了 ...
- Spark集群搭建_YARN
2017年3月1日, 星期三 Spark集群搭建_YARN 前提:参考Spark集群搭建_Standalone 1.修改spark中conf中的spark-env.sh 2.Spark on ...
- spark集群搭建
文中的所有操作都是在之前的文章scala的安装及使用文章基础上建立的,重复操作已经简写: 配置中使用了master01.slave01.slave02.slave03: 一.虚拟机中操作(启动网卡)s ...
- Spark 集群搭建
0. 说明 Spark 集群搭建 [集群规划] 服务器主机名 ip 节点配置 s101 192.168.23.101 Master s102 192.168.23.102 Worker s103 19 ...
- hadoop+spark集群搭建入门
忽略元数据末尾 回到原数据开始处 Hadoop+spark集群搭建 说明: 本文档主要讲述hadoop+spark的集群搭建,linux环境是centos,本文档集群搭建使用两个节点作为集群环境:一个 ...
- Spark集群搭建(local、standalone、yarn)
Spark集群搭建 local本地模式 下载安装包解压即可使用,测试(2.2版本)./bin/spark-submit --class org.apache.spark.examples.SparkP ...
- (四)Spark集群搭建-Java&Python版Spark
Spark集群搭建 视频教程 1.优酷 2.YouTube 安装scala环境 下载地址http://www.scala-lang.org/download/ 上传scala-2.10.5.tgz到m ...
- Spark集群搭建_Standalone
2017年3月1日, 星期三 Spark集群搭建_Standalone Driver: node1 Worker: node2 Worker: node3 1.下载安装 下载地址 ...
随机推荐
- centos 6 安装docker
安装 Fedora EPEL 1.yum -y install http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarc ...
- digitalocean完成B轮8300万美元融资,赠送10美元优惠码
7月8日,美国vps服务商digitalocean在官方博客宣传,公司完成高达8300万美元B轮融资.融资方包括 IA Ventures, Andreessen Horowitz和Access Ind ...
- 去除VisualStudio中拼写错误检测的红色波浪线
去除VisualStudio中拼写错误检测的红色波浪线 在Visual Assistant中将 Underline spelling errors in comments and strings us ...
- redis高级实用特性(1)
1.安全性 2.主从复制 3.事务处理 4.持久化机制 5.发布订阅消息 6.虚拟内存的使用 安全性:设置客户端连接后进行任何其他指定前需要使用的密码 警告:因为redis速度相当快,所以在一台比较好 ...
- 3.编写Java应用程序。首先定义一个描述银行账户的Account类,包括成员变 量“账号”和“存款余额”,成员方法有“存款”、“取款”和“余额查询”。其次, 编写一个主类,在主类中测试Account类的功能。
Account package com.hanqi.test; public class Account { private String zhanghao;private double yve; A ...
- bootstrap validator html attributes 选项
常用的html属性:data-fv-message="The username is not valid"data-fv-notempty="true"data ...
- MFC下调试日志的打印
最近项目出现点小Bug,需要调试跟踪代码,于是乎写了份打印日志的代码. CLogFile.h文件 #if !defined(AFX_LOGFILE_H__288388CA_9A3E_4F3D_A2B8 ...
- Vagrant常用命令
Vagrant常用命令 Vagrant的几个命令: vagrant box add 添加box的操作 vagrant init 初始化box的操作 vagrant up 启动虚拟机的操作 vagran ...
- 项目管理实践【五】自动编译和发布网站【Using Visual Studio with Source Control System to build and publish website automatically】
在上一篇教程项目管理实践[三]每日构建[Daily Build Using CruiseControl.NET and MSBuild] 中,我们讲解了如何使用CCNET+MSBuild来自动编译项目 ...
- ZOJ 649 Rescue(优先队列+bfs)
Rescue Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Sub ...