一、基本信息
快速入门 http://hadoop.apache.org/docs/r1.0.4/cn/quickstart.html
易百教程 https://www.yiibai.com/hadoop/
W3Cschool教程 https://www.w3cschool.cn/hadoop/?
二、环境、工具说明
1、操作系统 Centos7.4 x64 Minimal 1708
安装5台虚拟机
NameNode :2台 2G内存 1核CPU
DataNode :3台 2G内存 1核CPU
2、JDK版本:jdk1.8
3、工具:xshell5
4、VMware 版本:VMware Workstation Pro15
5、Hadoop:3.2.0
6、Zookeeper:3.4.5
三、安装部署(基础环境准备)
1、虚拟机安装(安装5台虚拟机)
2、每台虚拟机均接入互联网(5个节点均要配置好网卡)
网卡配置可参考:
3、修改主机名(5个节点均要修改主机名)
编辑集群中的各个节点主机名(以第一个节点 node1.cn 为例)
[root@localhost~]# hostnamectl set-hostname node1.cn
node1.cn
node2.cn
node3.cn
node4.cn
node5.cn
4、JDK8环境搭建(5个节点均要搭建)
5、配置防火墙(5个节点均要操作)
关闭防火墙,并设置开机禁止启动
关闭防火墙 : systemctl stop firewalld
查看状态 : systemctl status firewalld
开机禁用 : systemctl disable firewalld
6、配置静态IP
此处以node1.cn节点为例(其他节点 略):
[root@node1.cn ~]# vim /etc/sysconfig/network-scripts/ifcfg-ens33
说明:红框内为修改、增加的部分
7、配置hosts文件
此处以node1.cn节点为例:
[root@node1 ~]# vim /etc/hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.11.131 node1.cn
192.168.11.132 node2.cn
192.168.11.133 node3.cn
192.168.11.134 node4.cn
192.168.11.135 node5.cn
8、安装基本工具
[root@node1 ~]# yum install -y vim wget lrzsz tree zip unzip net-tools ntp
[root@node1 ~]# yum update -y (可选)
(根据自身的网络情况,可能需要等待几分钟)
9、配置节点间免密登录
具体步骤参照:
10、集群各节点修改系统文件打开数
此处以node1.cn节点为例:
[root@node1 ~]# vim /etc/security/limits.conf
参考
11、集群各节点配置时间同步
本文以阿里时间服务器为准,阿里云时间服务器地址:ntp6.aliyun.com
说明:如有专用时间服务器,请更改时间服务器的主机名或者IP地址,主机名需要在etc/hosts文件中做好映射。
以node1.cn为例:
设置系统时区为东八区(上海时区)
[root@node1 ~]# timedatectl set-timezone Asia/Shanghai
关闭ntpd服务
[root@node1 ~]# systemctl stop ntpd.service
设置ntpd服务禁止开机启动
[root@node1 ~]# systemctl disable ntpd
设置定时任务
[root@node1 ~]# crontab -e
写入以下内容(每10分钟同步一下阿里云时间服务器):
0-59/10 * * * * /usr/sbin/ntpdate ntp6.aliyun.com
重启定时任务服务
[root@node1 ~]# /bin/systemctl restart crond.service
设置定时任务开机启动
[root@node1 ~]# vim /etc/rc.local
加入以下内容后,保存并退出 :wq
/bin/systemctl start crond.service
集群中其他各个节点同node1.cn节点。
12、集群各节点禁用SELinux
以node1.cn为例:
[root@node1 ~]# vim /etc/selinux/config
修改如下内容后,保存并退出 :wq
集群中其他各个节点同node1.cn节点。
13、集群各节点禁用Transparent HugePages
14、配置系统环境为UTF8
以node1.cn为例:
[root@node1 ~]# echo "export LANG=zh_CN.UTF-8 " >> ~/.bashrc
[root@node1 ~]# source ~/.bashrc
集群中其他各个节点同node1.cn节点。
15、安装数据库
说明:安装MariaDb(Mysql)是为了给Hive、Spark、Oozie、Superset等提供元数据支持,如果用不到这些工具可以不安装Mysql数据库。
MariaDb(Mysql)安装过程可参照:
四、安装部署Hadoop集群(HA模式)
(注意:集群搭建和运行过程中,要确保集群中所有节点的时间要同步)
1、创建目录、文件上传、
说明:先在 node1.cn 上配置好基本信息,再把配置好的文件分发给各个节点,再进行进一步配置
在各个节点上创建目录 /opt/cluster/
以node1.cn为例:
[root@node1 ~]# mkdir /opt/cluster
2、文件下载(文件上传)、解压缩
直接下载
[root@node1 opt]# wget http://mirrors.tuna.tsinghua.edu.cn/apache/hadoop/common/hadoop-3.2.0/hadoop-3.2.0.tar.gz
或
手动下载文件:hadoop-3.2.0.tar.gz
把已下载好的文件 hadoop-3.2.0.tar.gz 上传至 /opt/cluster 路径下,并解压缩 hadoop-3.2.0.tar.gz
进入 /opt/cluster 目录
解压文件
[root@node1 cluster]# tar zxvf hadoop-3.2.0.tar.gz
查看目录结构
3、在 hadoop 中创建几个目录
[root@node1 ~]# mkdir /opt/cluster/hadoop-3.2.0/hdfs
[root@node1 ~]# mkdir /opt/cluster/hadoop-3.2.0/hdfs/tmp
[root@node1 ~]# mkdir /opt/cluster/hadoop-3.2.0/hdfs/name
[root@node1 ~]# mkdir /opt/cluster/hadoop-3.2.0/hdfs/data
[root@node1 ~]# mkdir /opt/cluster/hadoop-3.2.0/hdfs/journaldata
4、配置 hadoop 环境变量(追加 hadoop 的环境变量信息)
[root@node1 ~]# vim /etc/profile
在最后追加如下信息
export HADOOP_HOME="/opt/cluster/hadoop-3.2.0"
export PATH=$PATH:$HADOOP_HOME/bin:$HADOOP_HOME/sbin:$PATH
保存退出 :wq
使配置文件生效
[root@node1 ~]# source /etc/profile
查看版本
5、配置 hadoop-env.sh
[root@node1 ~]# vim /opt/cluster/hadoop-3.2.0/etc/hadoop/hadoop-env.sh
增加如下内容
export JAVA_HOME=/opt/utils/jdk1.8.0_191
export HDFS_NAMENODE_USER=root
export HDFS_DATANODE_USER=root
export HDFS_JOURNALNODE_USER=root
export HDFS_ZKFC_USER=root
export YARN_RESOURCEMANAGER_USER=root
export YARN_NODEMANAGER_USER=root
5、配置 core-site.xml
[root@node1 ~]# vim /opt/cluster/hadoop-3.2.0/etc/hadoop/core-site.xml
<configuration>
<property>
<name>fs.defaultFS</name>
<value>hdfs://cluster</value>
</property>
<property>
<name>hadoop.tmp.dir</name>
<value>/opt/cluster/hadoop-3.2.0/hdfs/tmp</value>
</property>
<property>
<name>ha.zookeeper.quorum</name>
<value>node3.cn:2181,node4.cn:2181,node5.cn:2181</value>
</property>
</configuration>
6、编辑文件 hdfs-site.xml
[root@node1 ~]# vim /opt/cluster/hadoop-3.2.0/etc/hadoop/hdfs-site.xml
<configuration>
<property>
<name>dfs.nameservices</name>
<value>cluster</value>
</property>
<property>
<name>dfs.ha.namenodes.cluster</name>
<value>nn1,nn2</value>
</property>
<property>
<name>dfs.replication</name>
<value>3</value>
</property>
<property>
<name>dfs.namenode.rpc-address.cluster.nn1</name>
<value>node1.cn:8020</value>
</property>
<property>
<name>dfs.namenode.rpc-address.cluster.nn2</name>
<value>node2.cn:8020</value>
</property>
<property>
<name>dfs.namenode.http-address.cluster.nn1</name>
<value>node1.cn:50070</value>
</property>
<property>
<name>dfs.namenode.http-address.cluster.nn2</name>
<value>node2.cn:50070</value>
</property>
<property>
<name>dfs.namenode.shared.edits.dir</name>
<value>qjournal://node3.cn:8485;node4.cn:8485;node5.cn:8485/cluster</value>
</property>
<property>
<name>dfs.namenode.name.dir</name>
<value>file:/opt/cluster/hadoop-3.2.0/hdfs/name</value>
</property>
<property>
<name>dfs.datanode.data.dir</name>
<value>file:/opt/cluster/hadoop-3.2.0/hdfs/data</value>
</property>
<property>
<name>dfs.journalnode.edits.dir</name>
<value>/opt/cluster/hadoop-3.2.0/hdfs/edits</value>
</property>
<property>
<name>dfs.ha.automatic-failover.enabled</name>
<value>true</value>
</property>
<property>
<name>dfs.journalnode.edits.dir</name>
<value>/opt/cluster/hadoop-3.2.0/hdfs/journaldata</value>
</property>
<property>
<name>dfs.client.failover.proxy.provider.cluster</name>
<value>org.apache.hadoop.hdfs.server.namenode.ha.ConfiguredFailoverProxyProvider</value>
</property>
<property>
<name>dfs.ha.fencing.methods</name>
<value>shell(/bin/true)</value>
</property>
<property>
<name>dfs.ha.fencing.methods</name>
<value>sshfence</value>
</property>
<property>
<name>dfs.ha.fencing.ssh.private-key-files</name>
<value>/root/.ssh/id_rsa</value>
</property>
<property>
<name>dfs.namenode.datanode.registration.ip-hostname-check</name>
<value>false</value>
</property>
</configuration>
7、编辑文件 mapred-site.xml
[root@node1 ~]# vim /opt/cluster/hadoop-3.2.0/etc/hadoop/mapred-site.xml
<configuration>
<property>
<name>mapreduce.framework.name</name>
<value>yarn</value>
</property>
<property>
<name>yarn.app.mapreduce.am.env</name>
<value>HADOOP_MAPRED_HOME=/opt/cluster/hadoop-3.2.0</value>
</property>
<property>
<name>mapreduce.map.env</name>
<value>HADOOP_MAPRED_HOME=/opt/cluster/hadoop-3.2.0</value>
</property>
<property>
<name>mapreduce.reduce.env</name>
<value>HADOOP_MAPRED_HOME=/opt/cluster/hadoop-3.2.0</value>
</property>
<property>
<name>mapreduce.jobhistory.address</name>
<value>node1.cn:10020</value>
</property>
<property>
<name>mapreduce.jobhistory.webapp.address</name>
<value>node1.cn:19888</value>
</property>
</configuration>
8、编辑文件 yarn-site.xml
[root@node1 ~]# vim /opt/cluster/hadoop-3.2.0/etc/hadoop/yarn-site.xml
<configuration>
<property>
<name>yarn.resourcemanager.ha.enabled</name>
<value>true</value>
</property>
<property>
<name>yarn.resourcemanager.cluster-id</name>
<value>cluster-yarn</value>
</property>
<property>
<name>yarn.resourcemanager.ha.rm-ids</name>
<value>rm1,rm2</value>
</property>
<property>
<name>yarn.resourcemanager.hostname.rm1</name>
<value>node1.cn</value>
</property>
<property>
<name>yarn.resourcemanager.hostname.rm2</name>
<value>node2.cn</value>
</property>
<property>
<name>yarn.resourcemanager.webapp.address.rm1</name>
<value>node1.cn:8088</value>
</property>
<property>
<name>yarn.resourcemanager.webapp.address.rm2</name>
<value>node2.cn:8088</value>
</property>
<property>
<name>yarn.resourcemanager.zk-address</name>
<value>node3.cn:2181,node4.cn:2181,node5.cn:2181</value>
</property>
<property>
<name>yarn.nodemanager.aux-services</name>
<value>mapreduce_shuffle</value>
</property>
<property>
<name>yarn.log-aggregation-enable</name>
<value>true</value>
</property> <property>
<name>yarn.log-aggregation.retain-seconds</name>
<value>106800</value>
</property>
</configuration>
9、配置文件 workers
[root@node1 ~]# vim /opt/cluster/hadoop-3.2.0/etc/hadoop/workers
node3.cn
node4.cn
node5.cn
10、把整个 hadoop-3.2.0 目录分发给各个节点
[root@node1 ~]# scp -r /opt/cluster/hadoop-3.2.0 node2.cn:/opt/cluster/
[root@node1 ~]# scp -r /opt/cluster/hadoop-3.2.0 node3.cn:/opt/cluster/
[root@node1 ~]# scp -r /opt/cluster/hadoop-3.2.0 node4.cn:/opt/cluster/
[root@node1 ~]# scp -r /opt/cluster/hadoop-3.2.0 node5.cn:/opt/cluster/
11、配置、启动 zookeeper
参考
12、指定的三个节点启动 journalnode
(此处我选择了node3.cn、node4.cn、node5.cn作为journalnode)
[root@node3 ~]# hdfs --daemon start journalnode
[root@node4 ~]# hdfs --daemon start journalnode
[root@node5 ~]# hdfs --daemon start journalnode
13、在 node1.cn 上格式化 namenode
[root@node1 ~]# hdfs namenode -format
14、在 node1.cn 上启动 namenode
[root@node1 ~]# hdfs --daemon start namenode
15、在 node2.cn 上同步 node1.cn 上已经格式化成功的 namenode信息
[root@node2 ~]# hdfs namenode -bootstrapStandby
16、在 node2.cn 上启动 namenode
[root@node2 ~]# hdfs --daemon start namenode
查看
17、关闭服务
(1)关闭 node1.cn 和 node2.cn 上的 namenode
[root@node1 ~]# hdfs --daemon stop namenode
[root@node2 ~]# hdfs --daemon stop namenode
(2)关闭 node3.cn、node4.cn、node5.cn 上的 JournalNode
[root@node3 ~]# hdfs --daemon stop journalnode
[root@node4 ~]# hdfs --daemon stop journalnode
[root@node5 ~]# hdfs --daemon stop journalnode
18、格式化 ZKFC
首先启动 node3.cn、node4.cn、node5.cn 上的 zookeeper
启动 zookeeper 后,在 node1.cn 节点上执行:
[root@node1 ~]# hdfs zkfc -formatZK
19、启动 hdfs、yarn 服务
[root@node1 ~]# /opt/cluster/hadoop-3.2.0/sbin/start-dfs.sh
[root@node1 ~]# /opt/cluster/hadoop-3.2.0/sbin/start-yarn.sh
20、查看各个节点的服务启动情况
至此,Centos7.4 搭建 Hadoop (HA)集群,操作完毕。
五、基本 shell 操作
(1)在 hdfs 中创建目录
[root@node1 ~]# hdfs dfs -mkdir /hadoop
[root@node1 ~]# hdfs dfs -mkdir /hdfs
[root@node1 ~]# hdfs dfs -mkdir /tmp
(2)查看目录
[root@node2 ~]# hdfs dfs -ls /
(3)上传文件
例如:在 /opt 目录下创建一个文件 test.txt 并写入一些单词(过程略)
[root@node3 ~]# hdfs dfs -put /opt/test.txt /hadoop
查看已上传的文件
[root@node4 ~]# hdfs dfs -ls /hadoop
[root@node4 ~]# hdfs dfs -cat /hadoop/test.txt
(4)删除文件
[root@node5 ~]# hdfs dfs -rm /hadoop/test.txt
Deleted /hadoop/test.txt
六、浏览器查看 部分服务的 UI 页面
1、查看 hdfs 的信息
分别查看node1.cn的ip和node2.cn的ip
其他页面:略。
2、查看 ResourceManager 信息
输入
或
其他页面:略。
七、运行 mapreduce wordcount
以上文的 test.txt 为例
[root@node5 ~]# /opt/cluster/hadoop-3.2.0/bin/yarn jar /opt/cluster/hadoop-3.2.0/share/hadoop/mapreduce/hadoop-mapreduce-examples-3.2.0.jar wordcount /hadoop /hadoop/output
在浏览器查看执行结果
ResourceManager 中执行的结果
查看执行结果
[root@node5 ~]# hdfs dfs -cat /hadoop/output/part-r-00000