1. 使用vm安装centos7.0
可以参考文章: CentOS 7.0系统安装配置步骤及网络开启配置详解(https://blog.csdn.net/youzhouliu/article/details/51175364)
2.配置linux虚拟机桥接模式,设置上网
第一个虚拟机,定为master
可参考文章: # 主机桥接Centos7联网问题总结
3.使用vm克隆两个虚拟机,组件集群
克隆的两个虚拟机,分别为slave1和slave2
4.修改slave1和slave2的ip,并通过配置使其能够联网
5. 修改mater,slave1和slave2的hostname
可参考文章: centos7配置SSH免密码登陆(https://blog.csdn.net/uuidanduid/article/details/60172998)
6.设置集群节点之间的免密码互访机制
可参考文章: centos7配置SSH免密码登陆(https://blog.csdn.net/uuidanduid/article/details/60172998)
7.使用xftp上传文件
这里是与centos6.5有所区别的地方,centos6.5可以通过共享文件夹的方式,上传文件.
而centos7.0不同通过简单设置共享文件夹的方式上传文件,还需要安装vm tools,相对复杂些.
而真正生产环境一般不用共享文件夹,而是更多使用xftp,所以此处选择使用xftp.
8.将所需要的安装包上传到/usr/local/src
目录下
这里主要使用的安装包有:
jdk-7u80-linux-x64.tar.gz
hadoop-2.6.1.tar.gz
需要的linux命令:
#解压命令: tar -zxvf jdk-7u80-linux-x64.tar.gz #跨节点复制命令: scp -rp jdk-7u80-linux-x64.tar.gz 192.168.175.21:/usr/local/src/ #或者 scp -rp jdk-7u80-linux-x64.tar.gz slave1:/usr/local/src/
需要在~/.bashrc
进行如下方式的配置
iptables -F #强制关闭防火墙 setenforce 0 hostname master export JAVA_HOME=/usr/local/src/jdk1.7.0_80 export HADOOP_HOME=/usr/local/src/hadoop-2.6.1 # added by Anaconda3 #export PATH =/root/anaconda3/bin:$PATH export CLASSPATH=.:$CLASSPATH:$JAVA_HOME/lib export PATH=$HADOOP_HOME/bin:$JAVA_HOME/bin:$PATH
9. 在jdk安装完成后,就可以配置hadoop2.0了.
配置hadoop文件所在的路径为:/usr/local/src/hadoop-2.6.1/etc/hadoop
9.1 在hadoop-env.sh中配置JAVA_HOME
# The java implementation to use. export JAVA_HOME=/usr/local/src/jdk1.7.0_80
9.2 在yarn-env.sh中配置JAVA_HOME
# some Java parameters export JAVA_HOME=/usr/local/src/jdk1.7.0_80
9.3 在slaves中配置从节点
slave1 slave2
9.4 在core-site.xml中配置如下:
<property> <name>fs.defaultFS</name> <value>hdfs://master:9000</value> </property> <property> <name>hadoop.tmp.dir</name> <value>file:/usr/local/src/hadoop-2.6.1/tmp</value> <description>Abase for other temporary directories.</description> </property>
9.5 在HADOOP_HOME创建如下目录:tmp,dfs/name,dfs/data
执行命令:
mkdir tmp mkdir -p dfs/name mkdir -p dfs/data
9.6 在hdfs-site.xml中进行如下配置:
<!-- Put site-specific property overrides in this file. --> <configuration> <property> <name>dfs.replication</name> <value>3</value> </property> <property> <name>dfs.namenode.secondary.http-address</name> <value>master:9001</value> </property> <property> <name>dfs.namenode.name.dir</name> <value>file:/usr/local/src/hadoop-2.6.1/dfs/name</value> </property> <property> <name>dfs.datanode.data.dir</name> <value>file:/usr/local/src/hadoop-2.6.1/dfs/data</value> </property> </configuration>
9.7 修改mapred-site.xml.template文件名->mapred-site.xml
执行命令:
cp mapred-site.xml.template mapred-site.xml
在mapred-site.xml进行如下配置:
<!-- Put site-specific property overrides in this file. --> <configuration> <property> <name>mapreduce.framework.name</name> <value>yarn</value> </property> </configuration>
9.8 在yarn-site.xml中进行如下配置:
<configuration> <!-- Site specific YARN configuration properties --> <property> <name>yarn.nodemanager.aux-services</name> <value>mapreduce_shuffle</value> </property> <property> <name>yarn.nodemanager.auxservices.mapreduce.shuffle.class</name> <value>org.apache.hadoop.mapred.ShuffleHandler</value> </property> <property> <name>yarn.resourcemanager.address</name> <value>master:8032</value> </property> <property> <name>yarn.resourcemanager.scheduler.address</name> <value>master:8030</value> </property> <property> <name>yarn.resourcemanager.resource-tracker.address</name> <value>master:8035</value> </property> <property> <name>yarn.resourcemanager.admin.address</name> <value>master:8033</value> </property> <property> <name>yarn.resourcemanager.webapp.address</name> <value>master:8088</value> </property> </configuration>
9.9 将配置好的hadoop-2.6.1文件夹,依次复制到其他两个节点上
操作命令如下:
scp -rp hadoop-2.6.1 slave1:/usr/local/src/
9.10 类似master在~/.bashrc
的环境变量配置,在slave1和slave2同样进行配置,记得修改hostname
9.11 一切准备就绪,开始格式化并启动集群
命令如下:
#格式化 ./bin/hadoop namenode -format #启动 ./sbin/start-dfs.sh ./sbin/start-yarn.sh
9.12 测试集群启动情况,在各个节点执行jps命令:
在master节点正常启动的话,会显示如下:
SecondaryNameNode Jps NameNode ResourceManager
在slave1和slave2节点应显示如下:
NodeManager Jps DataNode
9.13 测试集群能否上传与读取文件
命令如下:
#上传文件:(自己随便创建一个文件即可) hadoop fs -put /usr/local/src/test / #查看文件类表: hadoop fs -ls / #读取文件: hadoop fs -text /test
配置流程,可参考文章: