hadoop集群环境搭建

1 介绍

1.1 系统版本介绍

此文档编写使用的系统为ubuntu-18.04.1-live-server-amd64.iso版本。

1.2 软件版本介绍

软件 版本
jdk jdk-8u181-linux-x64.tar.gz
hadoop hadoop-2.7.7.tar.gz

1.3 ubuntu集群服务器

主机名 IP地址 服务
Master 10.168.1.216 ResourceManager、SecondaryNameNode、NameNode
slave01 10.168.1.217 NodeManager、DataNode
slave02 10.168.1.218 NodeManager、DataNode
slave03 10.168.1.219 NodeManager、DataNode

1.4 说明

本文档安装jdk和ssh略过。

2 安装hadoop集群

2.1 全局配置

2.1.1 解压hadoop

创建一个hadoop的文件夹,用户存放hadoop文件

mkdir /usr/local/hadoop

通过ftp工具把下载好的hadoop安装包上传到hadoop文件夹下。
解压:

cd /usr/local/hadoop
tar -vxzf hadoop-2.7.7.tar.gz

解压完成:

1.png

移动hadoop-2.7.7文件下的文件到当前的目录

mv ./hadoop-2.7.7/* ./

删除hadoop-2.7.7文件夹

rm -rf ./hadoop-2.7.7

查看文件夹的所有者以及用户组,最重要的是拥有者是否是当前用户

2.png

如果拥有者不是当前用户,则修改为当前用户:

chown -R 当前用户名 ./hadoop

2.1.2 配置hadoop

设置环境变量:

vim /etc/profile

在末尾添加:

JAVA_HOME=/usr/local/java/jdk1.8.0_181
HADOOP_HOME=/usr/local/hadoop
PATH=$PATH:$HOME/bin:$JAVA_HOME/bin:$HADOOP_HOME/bin:$HADOOP_HOME/sbin
export JAVA_HOME
export PATH
export HADOOP_HOME

重新加载环境变量的配置文件:
source /etc/profile

检测:
hadoop version

3.png

2.1.3 修改配置文件

在core-site.xml 中添加

<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" href="configuration.xsl"?>
<configuration>
  <property>
    <name>fs.defaultFS</name>
    <value>hdfs://master:9000</value>
  </property>
  <property>
    <name>hadoop.tmp.dir</name>
    <value>/usr/local/hadoop/tmp</value>
  </property>
</configuration>
4.png

在 hdfs-site.xml 中添加

<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" href="configuration.xsl"?>
<configuration>
  <property>
    <name>dfs.namenode.secondary.http-address</name>
    <value>master:9001</value>
  </property>
  <property>
    <name>dfs.name.dir</name>
    <value>/usr/local/hadoop/hdfs/name</value>
  </property>
  <property>
    <name>dfs.data.dir</name>
    <value>/usr/local/hadoop/hdfs/data</value>
  </property>
  <!--副本的数量-->
  <property>
    <name>dfs.replication</name>
    <value>3</value>
  </property>
  <property>
    <name>dfs.permissions</name>
    <value>false</value>
  </property>
</configuration>
5.png

hadoop-env.sh 中更改 JAVA_HOME

注释掉:

export JAVA_HOME=${JAVA_HOME}

添加:

export JAVA_HOME=/usr/local/java/jdk1.8.0_181

修改slaves文件,添加如下信息:

vim /usr/local/Hadoop/etc/Hadoop/slaves

6.png

1.2 特殊配置

2.2.1 复制三台主机

7.png

2.2.2 设置静态ip地址

前言

Ubuntu 18.04不再使用ifupdown配置网络,而改用netplan。在/etc/network/interfaces配置固定IP是无效的,重启网络的命令services network restrart/etc/init.d/networking restart也是无效的。

使用ifupdown配置网络

如果要使用之前的方式配置网络,需要重新安装ifupdown:

apt install ifupdown

修改配置文件/etc/network/interfaces:

vim /etc/network/interfaces

配置文件修改如下:

iface ens160 inet static
address 210.72.92.25
gateway 210.72.92.254
netmask 255.255.255.0
dns-nameservers 8.8.8.8

重启网络服务使配置生效

services network restrart

使用netplan配置网络

Ubuntu 18.04使用netplan配置网络,其配置文件是yaml格式的。安装好Ubuntu 18.04之后,在/etc/netplan/目录下默认的配置文件名是50-cloud-init.yaml,我们通过VIM修改它:

vim /etc/netplan/50-cloud-init.yaml

配置文件修改如下:

network:
  ethernets:
    ens160:
      addresses: [10.168.1.216/24]
      dhcp4: false
      gateway4: 10.168.1.254
  version: 2

无论是ifupdown还是netplan,配置的思路都是一致的,在配置文件里面按照规则填入IP、掩码、网关、DNS等信息。注意yaml是层次结构,需要缩进,冒号(:)表示字典,连字符(-)表示列表。

重启网络服务使配置生效:

netplan apply

8.png

2.2.3 配置hosts文件

vim /etc/hosts

添加master和slaves信息:

9.png

2.2.4 本地主机名配置

首先修改

vim /etc/cloud/cloud.cfg

disable_root:false修改为true

10.png

修改主机名:

vim /etc/hostname

将10.168.1.216主机名修改为master。

11.png

将其他机器也修改为对应的名称,重启所有服务器。

2.2.5 多服务器ssh免密码登陆

由于Hadoop启动以后,namenode是通过SSH(Secure Shell)来启动和停止各个节点上的各种守护进程的,这就需要在节点之间执行指令的时候是不需要输入密码的方式,故我们需要配置SSH使用无密码公钥认证的方式(安装ssh,配置ssh远程连接过程略过。)

所有服务器使用rsa算法生成秘钥和公钥对:
ssh-keygen -t rsa

12.png

然后把master服务器中公钥加入到授权中:

cat ./id_rsa.pub >> ./authorized_keys

使用ssh localhost验证是否无密码登陆。

把slave服务器中的id_rsa.pub复制到master中:

scp .ssh/id_rsa.pub root@master:/

13.png

查看公钥是否复制成功:

14.png

将公钥添加到master的授权文件中:

cat /id_rsa.pub >> ~/.ssh/authorized_keys

重复上面步骤,直到所有的slave公钥都添加到了授权文件中。

15.png

将授权文件分发到每台服务器上:

scp ~/.ssh/authorized_keys username@hostname: ~/.ssh/authorized_keys

测试通过ssh相互之间登录:

ssh hostname

username:服务器用户名。
hostname:服务器主机名。

测试完毕重启服务器。

2.2.6 启动hadoop

在master服务器上格式化namenode节点:

hadoop namenode -format

16.png

启动hdfs

start-all.sh

17.png

查看相应的进程:

jps

master:

18.png

确定3个进程全部启动。

slave:

19.png

确定2个进程全部启动。

访问测试:

10.168.1.216:50070

20.png
21.png
22.png

1.3 添加datanode节点

配置一台新的slave机器,根据前面的步骤配置网络IP。

启动datanode服务:

hadoop-daemon.sh start datanode

启动nodemanager服务:

yarn-daemon.sh start nodemanager

23.png

如果需要在name节点启动的时候,同时也启动这台新加的data节点,那么需要根据特殊配置的步骤,修改hosts文件、服务器主机名、以及ssh免密登录等,才能通过name来启动data节点。

1.4 删除datanode节点

首先需要在hdfs-site.xml添加:

<property>
  <name>dfs.hosts.exclude</name>
  <value>/usr/local/hadoop/etc/hadoop/excludes</value>
</property>
24.png

然后在对应位置创建文件:
vim /usr/local/hadoop/etc/hadoop/excludes
在文件中加入要删除的节点名称:

27.png

例如要删除的节点是slave03

25.png

在NameNode上刷新所有DataNode:

hdfs dfsadmin -refreshNodes    #刷新节点信息
start-balancer.sh              #同步节点的数据
26.png

如下图:表示与该节点已经断开了连接(因为hadoop心跳检测是10分钟,所以如果是data节点宕机,就会一直检测,直到超时)。

接下来就可以关闭data节点了:

关闭datanode服务:

hadoop-daemon.sh stop datanode

关闭nodemanager服务:

yarn-daemon.sh stop nodemanager

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,222评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,455评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,720评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,568评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,696评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,879评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,028评论 3 409
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,773评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,220评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,550评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,697评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,360评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,002评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,782评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,010评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,433评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,587评论 2 350

推荐阅读更多精彩内容