本文详细介绍搭建4个节点的完全分布式Hadoop集群的方法,Linux系统版本是CentOS 7,Hadoop版本是2.7.7,JDK版本是1.8。
一、准备环境
1. 在VMware workstations上创建4个Linux虚拟机,并配置其静态IP。
有关【创建Linux虚拟机及配置网络】,请参考这里。
2. 配置DNS(每个节点)
编辑配置文件,添加主节点和从节点的映射关系。
#vim /etc/hosts 192.168.44.3 hadoop01 192.168.44.4 hadoop02 192.168.44.5 hadoop03 192.168.44.6 hadoop04
3. 关闭防火墙(每个节点)
#关闭服务 [root@hadoop01 opt]# systemctl stop firewalld #关闭开机自启动 [root@hadoop01 opt]# systemctl disable firewalld Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service. Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
4. 配置免密码登录
有关【配置免密码登录方法】,请参考这里。
5. 配置Java环境(每个节点)
有关【配置java环境方法】,请参考这里。
二、搭建Hadoop完全分布式集群
在各个节点上安装与配置Hadoop的过程都基本相同,因此可以在每个节点上安装好Hadoop后,在主节点master上进行统一配置,然后通过scp 命令将修改的配置文件拷贝到各个从节点上即可。
1. 下载Hadoop安装包,解压,配置Hadoop环境变量
有关【Hadoop安装包下载方法】,请参考这里。
本文下载的Hadoop版本是2.7.7,指定一个目录(比如:/opt),使用rz命令上传Hadoop安装包到Linux系统,解压到指定目录,配置Hadoop环境变量,并使其生效。实现命令如下:
#解压到/opt目录
[root@hadoop01 opt]# tar -zxvf hadoop-2.7.7.tar.gz
#链接/opt/hadoop-2.7.7到/opt/hadoop,方便后续配置
[root@hadoop01 opt] #ln -s hadoop-2.7.7 hadoop
#配置Hadoop环境变量
[root@hadoop02 opt]# vim /etc/profile #Hadoop export HADOOP_HOME=/opt/hadoop # 该目录为解压安装目录 export PATH=$PATH:$HADOOP_HOME/bin export PATH=$PATH:$HADOOP_HOME/sbin export HADOOP_CONF_DIR=${HADOOP_HOME}/etc/hadoop #保存后,使profile生效 [root@hadoop02 opt]# source /etc/profile
2. 配置Hadoop环境脚本文件中的JAVA_HOME参数
#进入Hadoop安装目录下的etc/hadoop目录 [root@hadoop01 ~]#cd /opt/hadoop/etc/hadoop #分别在hadoop-env.sh、mapred-env.sh、yarn-env.sh文件中添加或修改如下参数:
[root@hadoop01 hadoop]# vim hadoop-env.sh
[root@hadoop01 hadoop]# vim mapred-env.sh
[root@hadoop01 hadoop]# vim yarn-env.sh
export JAVA_HOME="/opt/jdk" # 路径为jdk安装路径
3. 修改Hadoop配置文件
Hadoop安装目录下的etc/hadoop目录中,需修改core-site.xml、hdfs-site.xml、mapred-site.xml、yarn-site.xml、slaves(3.0之后为workers)文件,根据实际情况修改配置信息。
(1)core-site.xml
12 3 4 7fs.defaultFS 5hdfs://hadoop01:9000 68 9 12 13hadoop.tmp.dir 10/opt/hadoop-2.7.7/tmp 1114 17hadoop.proxyuser.root.hosts 15* 1618 21hadoop.proxyuser.root.groups 19* 20
更多配置信息,请参考core-site.xml。
(2)hdfs-site.xml
12 3 4 7dfs.namenode.http-address 5hadoop01:50070 68 11dfs.namenode.name.dir 9file:/opt/hadoop/dfs/name 1012 15dfs.datanode.data.dir 13file:/opt/hadoop/dfs/data 1416 17 20dfs.replication 182 1921 22 25dfs.namenode.secondary.http-address 23hadoop02:9001 2426 29dfs.webhdfs.enabled 27true 2830 34dfs.permissions 31false 32配置为false后,可以允许不要检查权限就生成dfs上的文件,需防止误删操作 33
更多配置信息,请参考hdfs-site.xml。
(3)mapred-site.xml
12 3 6mapreduce.framework.name 4yarn 57 10mapreduce.jobhistory.address 8hadoop01:10020 911 14mapreduce.jobhistory.webapp.address 12hadoop01:19888 13
更多配置信息,请参考mapred-site.xml。
(4)yarn-site.xml
12 3 6yarn.nodemanager.aux-services 4mapreduce_shuffle 57 10yarn.nodemanager.auxservices.mapreduce.shuffle.class 8org.apache.hadoop.mapred.ShuffleHandler 911 14yarn.resourcemanager.address 12hadoop01:8032 1315 18yarn.resourcemanager.scheduler.address 16hadoop01:8030 1719 22yarn.resourcemanager.resource-tracker.address 20hadoop01:8031 2123 26yarn.resourcemanager.admin.address 24hadoop01:8033 2527 30 31yarn.resourcemanager.webapp.address 28hadoop01:8088 2932 37yarn.nodemanager.resource.memory-mb 33 356144 3638 40 43yarn.scheduler.maximum-allocation-mb 4161440 4244 45 48 49yarn.nodemanager.resource.cpu-vcores 462 4750 53yarn.log-aggregation-enable 51true 5254 57yarn.log-aggregation.retain-seconds 55604800 5658 62yarn.nodemanager.vmem-check-enabled 59false 60忽略虚拟内存的检查,如果你是安装在虚拟机上,这个配置很有用,配上去之后后续操作不易出问题。 6163 64 67yarn.resourcemanager.scheduler.class 65org.apache.hadoop.yarn.server.resourcemanager.scheduler.fair.FairScheduler 66
更多配置信息,请参考yarn-site.xml。
(5)slaves文件
#增加从节点地址(若配置了hosts,可直接使用主机名,亦可用IP地址)
[root@hadoop01 hadoop]# vim slaves
hadoop02
hadoop03
hadoop04
4. 将配置好的文件夹拷贝到其他从节点
[root@hadoop01 hadoop-2.7.7]# scp -r /opt/hadoop-2.7.7 root@hadoop02:/opt/
[root@hadoop01 hadoop-2.7.7]# scp -r /opt/hadoop-2.7.7 root@hadoop03:/opt/
[root@hadoop01 hadoop-2.7.7]# scp -r /opt/hadoop-2.7.7 root@hadoop04:/opt/
5. 初始化 & 启动
#格式化 [root@hadoop01 hadoop-2.7.7]# bin/hdfs namenode -format #启动 [root@hadoop01 hadoop-2.7.7]# sbin/start-dfs.sh [root@hadoop01 hadoop-2.7.7]# sbin/start-yarn.sh
6. 验证Hadoop启动成功
#主节点 [root@hadoop01 hadoop-2.7.7]# jps 5895 Jps 5624 ResourceManager 5356 NameNode #从节点 [root@hadoop02 hadoop]# jps 5152 SecondaryNameNode 5085 DataNode 5245 NodeManager 5357 Jps [root@hadoop03 opt]# jps 5080 DataNode 5178 NodeManager 5278 Jps [root@hadoop04 opt]# jps 5090 NodeManager 5190 Jps 4991 DataNode
7. Hadoop Web端口访问
注:先开放端口或直接关闭防火墙
# 查看防火墙状态 firewall-cmd --state # 临时关闭 systemctl stop firewalld # 禁止开机启动 systemctl disable firewalld
在浏览器输入:http://hadoop01:8088,打开Hadoop Web管理页面。
在浏览器输入:http://hadoop01:50070打开Hadoop Web页面。
注意:如果输入主节点名称无法打开Web页面,则需要配置Windows上的hosts,路径如下:
C:\Windows\System32\drivers\etc\hosts
192.168.44.5 hadooop01 192.168.44.6 hadooop02 192.168.44.7 hadooop03 192.168.44.8 hadooop04