易陆发现互联网技术论坛

 找回密码
 开始注册
查看: 5051|回复: 0
收起左侧

CentOS 7.2 下配置Hadoop3.0 教程

[复制链接]
发表于 2016-11-20 13:10:22 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?开始注册

x
说明:
本文的部署方式是传统的解压包方式和Linux标准方式。配置的基本环境是Win10下的VMware Workstation12.1proLinux版本为CentOS 7.2Hadoop版本为Hadoop3.0.0。部署完成后是一个cMaster主节点节点和两个从节点(cSlave0cSlave1),均运行在VMware虚拟机中。本文仅保证在该环境下配置能够正常使用,其他环境请自行酌情修改。
配置步骤:
1. 准备资源和环境。
下载Centos 7.2 iso安装镜像,jdk1.8 for Linux压缩包,hadoop3.0.0压缩包。下载链接分别如下:
http://www.Oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html
下载完成后如图所示
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image001.jpg
2. 安装虚拟机。
Vmware workstation中用典型 typical 方式安装Centos7 ,每个虚拟机的资源为单核、1G内存、20GB磁盘。网络类型为NAT
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image002.png
在安装的时候机器名称设置为cMaster(注意此处的名称只是在Vmware中的一个标识而已,真正新安装的centos7 系统里的机器名都为localhost.localdomain
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image003.png
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image005.jpg
用户名使用joe 密码也为joe(可自行更改)
重复以上步骤,分别安装cSlave0cSlave1两个从节点的虚拟机。
(只是在机器名处分别填写cSlave0 cSlave1,其他步骤都相同)
注意:centos7默认是进行最小化安装,安装完成后是不带有图形化界面。如果需要图形化界面在软件安装选项里要勾选上gnome
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image007.jpg
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image009.jpg
3. 修改配置文件。
当三台虚拟机均安装完成后,需要进行的是修改机器名、添加域名映射、关闭防火墙,并安装jdk
1  修改机器名。
打开终端,切换到root用户下修改机器名称。
$ sudo su
$ vim /etc/sysconfig/network
在其中添加“HOSTNAME=cMaster”,然后重启当前虚拟机,再查看机器名就是cMaster了。
(如果重启之后机器名不是cMaster,可以使用命令hostnamectl set-hostnamecMaster 修改机器名)
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image010.png
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image011.png
2  添加域名映射
使用ifconfig命令分别查看三台虚拟机的IP地址。然后将三个ip地址都添加到各自的/etc/hosts文件中。
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image012.png
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image013.png
3台机器均修改完成后,使用pingslave0/cmaster/cslave1命令测试各机器之间是否能够正常通三台机信。如果出现下图所示信息说明通信正常。
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image014.png
3  关闭当前机器的防火墙。
root权限下执行以下两条指令,关闭防火墙并阻止其开机启动。
systemctl stop firewalld.service#停止firewall/ `: x7 J  `! V6 c
systemctl disable firewalld.service#禁止firewall开机启动
4  安装JDK
将之前下载好的jdk复制到虚拟机中的/home/joe/目录下,
使用命令rpm –ivh /home/joe/jdk-8u101-linux-x64.rpm解压安装
安装完成后使用javac命令测试jdk是否安装成功,如果出现了如下图提示,说明安装jdk成功。
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image015.png
4.解压hadoop,部署hadoop
1)按照以上步骤配置完成后,最好重启一下所有机器,确保所有的设置生效。
然后利用joe账户分别登录三台机器。将事先下载好的hadoop压缩包复制到每台机器的/home/joe/目录下,然后在每一台机器上分别使用
tar–zxvf /home/joe/hadoop-3.0.0-alpha1.tar.gz 命令解压安装hadoop3.0.
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image016.png
2)解压完成后需要修改hadoop的配置文件。
(本小节步骤在三台机器上都完全相同,三台机器都需要进行修改)
A.使用如下指令编辑hadoop-env.sh文件
gedit/home/joe/hadoop-3.0.0-alpha1/etc/hadoop/hadoop-env.sh
在文件中找到exportJAVA_HOME=${JAVA_HOME}
修改为exportJAVA_HOME=/usr/java/jdk1.8.0_101(填写自己安装的jdk的路径)
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image017.png
B.修改core-site.xml文件
使用命令gedit/home/joe/hadoop-3.0.0-alpha1/etc/hadoop/core-site.xml
<configuration>标签之间插入以下内容。
<property><name>hadoop.tmp.dir</name><value>/home/joe/cloudData</value></property>
<property><name>fs.defaultFS</name><value>hdfs://cMaster:8020</value></property>
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image019.jpg
C.修改yarn-site.xml文件
使用以下命令修改gedit /home/joe/hadoop-3.0.0-alpha1/etc/hadoop/yarn-site.xml
<configuration>标签之间插入以下内容
<property><name>yarn.resourcemanager.hostname</name><value>cMaster</value></property>
<property><name>yarn.nodemanager.aux-services</name><value>mapreduce_shuffle</value></property>
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image021.jpg
D.修改mapred-site.xml.template
/home/joe/hadoop-3.0.0-alpha1/etc/hadoop/目录下的mapred-site.xml.template重命名为mapred-site.xml
并用命令gedit/home/joe/hadoop-3.0.0-alpha1/etc/hadoop/mapred-site.xml
<configuration>标签之间加入如下内容:
<property><name>mapreduce.framework.name</name><value>yarn</value></property>
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image022.png
E.启动hadoop
首先格式化主节点命名空间,使用命令:
/home/joe/hadoop-3.0.0-alpha1/bin/hdfsnamenode–formate
其次在主节点上启动存储服务和资源管理主服务。使用命令:
/home/joe/hadoop-3.0.0-alpha1/sbin/hadoop-daemon.shstart namenode #启动主存储服务
/home/joe/hadoop-3.0.0-alpha1/sbin/yarn-daemon.shstart resourcemanager # 启动资源管理服务。
最后在从节点上启动存储从服务和资源管理从服务(以下两条命令要在两台机器上分别执行)
/home/joe/hadoop-3.0.0-alpha1/sbin/hadoop-daemon.shstart datanode #启动从存储服务
/home/joe/hadoop-3.0.0-alpha1/sbin/yarn-daemon.shstart nodemanager #启动资源管理从服务
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image024.jpg
服务启动后在三台机器上分别使用jps命令查看是否启动。
cSlave0cSlave1如下图所示
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image025.png
cMaster节点显示如下图所示
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image026.png
cMaster机器的浏览器地址栏里输入cMaster50070可以看到HDFS的相关信息,cMaster8088可以看到Yarn的相关信息。
如图还可以查看从节点的信息。
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image028.jpg
至此 Hadoop3.0的配置工作已经完成了。接下来可以使用示例程序Wordcount来利用分布式系统统计某个文件中单词出现的次数。
cMaster上以joe用户登录,然后执行以下的操作命令:
  cd/home/joe/hadoop-3.0.0-alpha1/
bin/hdfs dfs -mkdir /in
bin/hdfs dfs-put/home/joe/hadoop-3.0.0-alpha1/etc/hadoop/* /in
bin/hadoopjarshare/hadoop/mapreduce/hadoop-mapreduce-examples-3.0.0-alpha1.jar wordcount /in /out/wc
如下图,在浏览器中输入cMaster50070 可以看到hdfs,切换到相应文件夹下可以看到统计出的结果。
file:///C:/Users/admin/AppData/Local/Temp/msohtmlclip1/01/clip_image030.jpg
8 l$ Q/ B6 E% P1 p- N) ?( i) v

: Y& I+ z& V' `: a
* G4 x8 L* @3 k7 E
- L/ ^2 a/ j" w% e; C( K: V

- u; K; L& W, ^5 W8 }( N1 X6 i
说明:
本文的部署方式是传统的解压包方式和Linux标准方式。配置的基本环境是Win10下的VMware Workstation12.1pro,Linux版本为CentOS 7.2,Hadoop版本为Hadoop3.0.0。部署完成后是一个cMaster主节点节点和两个从节点(cSlave0和cSlave1),均运行在VMware虚拟机中。本文仅保证在该环境下配置能够正常使用,其他环境请自行酌情修改。
配置步骤:
1. 准备资源和环境。
下载Centos 7.2 的iso安装镜像,jdk1.8 for Linux压缩包,hadoop3.0.0压缩包。下载链接分别如下:
http://www.Oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html
下载完成后如图所示
: H/ ^3 H% }1 q- k- ?
                               
登录/注册后可看大图

3 A! Z. @; m2 E7 r, Y8 [, a
2. 安装虚拟机。
在Vmware workstation中用典型 typical 方式安装Centos7 ,每个虚拟机的资源为单核、1G内存、20GB磁盘。网络类型为NAT。
1 y$ V7 W( ?% M4 t- S
                               
登录/注册后可看大图

0 g$ J( A8 k7 a
( {9 J4 s+ E7 m. g: J) c
在安装的时候机器名称设置为cMaster(注意此处的名称只是在Vmware中的一个标识而已,真正新安装的centos7 系统里的机器名都为localhost.localdomain)
$ T$ e" p1 X- T! L, t/ E8 B
                               
登录/注册后可看大图

+ I. @2 P! @" i- H+ |" z& R/ R5 X                               
登录/注册后可看大图

8 a  v5 k- \  }. P

- ?& B3 E* A6 y& o; t8 ]+ Q
用户名使用joe 密码也为joe(可自行更改)
重复以上步骤,分别安装cSlave0和cSlave1两个从节点的虚拟机。
(只是在机器名处分别填写cSlave0 和cSlave1,其他步骤都相同)
注意:centos7默认是进行最小化安装,安装完成后是不带有图形化界面。如果需要图形化界面在软件安装选项里要勾选上gnome。
% G. \9 A% N% Y2 f8 C+ a
                               
登录/注册后可看大图
. z, n( f+ ^) P6 W9 i+ _
                               
登录/注册后可看大图
3. 修改配置文件。
当三台虚拟机均安装完成后,需要进行的是修改机器名、添加域名映射、关闭防火墙,并安装jdk。
(1)  修改机器名。
打开终端,切换到root用户下修改机器名称。
$ sudo su
$ vim /etc/sysconfig/network

4 f) ^; |: U2 r3 B' d
! [, m; a: ?* s3 u
在其中添加“HOSTNAME=cMaster”,然后重启当前虚拟机,再查看机器名就是cMaster了。
(如果重启之后机器名不是cMaster,可以使用命令hostnamectl set-hostnamecMaster 修改机器名)

, z) P' I% P( ?                               
登录/注册后可看大图

' @, S( h4 d: V6 f

9 ^0 `1 p  i1 H% Y                               
登录/注册后可看大图
$ ?# }. V5 V% T- b  U$ o) x1 v
  v) Z+ d/ F3 _

3 `7 i; M( @& G7 @, o  G8 U
(2)  添加域名映射
使用ifconfig命令分别查看三台虚拟机的IP地址。然后将三个ip地址都添加到各自的/etc/hosts文件中。
. z8 t% u) ^  E1 I/ O7 g
                               
登录/注册后可看大图
, k" E: R8 I% M5 c8 L" b3 p

7 f, o9 I% a/ w0 ?/ g6 x                               
登录/注册后可看大图

/ Q5 H" Q  d1 v! w, S
8 Z6 b6 R+ `2 \& m: R
7 N9 e2 N0 }# [4 i! @1 u
3台机器均修改完成后,使用pingslave0/cmaster/cslave1命令测试各机器之间是否能够正常通三台机信。如果出现下图所示信息说明通信正常。

; l$ b* @. C( A4 ?1 ~7 M  m+ K                               
登录/注册后可看大图

8 K1 [+ I' ?# W! o$ m' A

% V6 `0 @% z3 B9 }
(3)  关闭当前机器的防火墙。
在root权限下执行以下两条指令,关闭防火墙并阻止其开机启动。
systemctl stop firewalld.service#停止firewall
1 k) w; V9 K( p  l0 ?3 |systemctl disable firewalld.service#禁止firewall开机启动
(4)  安装JDK。
将之前下载好的jdk复制到虚拟机中的/home/joe/目录下,
使用命令rpm –ivh /home/joe/jdk-8u101-linux-x64.rpm解压安装
安装完成后使用javac命令测试jdk是否安装成功,如果出现了如下图提示,说明安装jdk成功。
0 d+ \  y: v7 ]7 w$ `( c
                               
登录/注册后可看大图

4 j) R$ }8 M, b( [9 o+ b
6 B7 G) M# c- Q/ [9 B9 h' H) ?. Y
4.解压hadoop,部署hadoop
(1)按照以上步骤配置完成后,最好重启一下所有机器,确保所有的设置生效。
然后利用joe账户分别登录三台机器。将事先下载好的hadoop压缩包复制到每台机器的/home/joe/目录下,然后在每一台机器上分别使用
tar–zxvf /home/joe/ hadoop-3.0.0-alpha1.tar.gz 命令解压安装hadoop3.0.

7 p3 F: R1 H! J8 C1 B                               
登录/注册后可看大图
( V( @) w. ~, f) V/ c

- k# @# t- v; q) q/ D4 f
(2)解压完成后需要修改hadoop的配置文件。
(本小节步骤在三台机器上都完全相同,三台机器都需要进行修改)
A.使用如下指令编辑hadoop-env.sh文件
gedit/home/joe/hadoop-3.0.0-alpha1/etc/hadoop/hadoop-env.sh
: z7 ?: t5 V/ X
在文件中找到exportJAVA_HOME=${JAVA_HOME}
修改为exportJAVA_HOME=/usr/java/jdk1.8.0_101(填写自己安装的jdk的路径)

1 _, T2 S+ L2 }" U/ [, A                               
登录/注册后可看大图
5 E" X3 Q, x* J

9 N0 ?, w) S3 `# Z( X& [
B.修改core-site.xml文件
使用命令gedit/home/joe/hadoop-3.0.0-alpha1/etc/hadoop/core-site.xml
在<configuration>标签之间插入以下内容。
<property><name>hadoop.tmp.dir</name><value>/home/joe/cloudData</value></property>
<property><name>fs.defaultFS</name><value>hdfs://cMaster:8020</value></property>
2 U& B) _' C* ^* i9 g- f7 h
                               
登录/注册后可看大图

1 `6 b& ^: x6 K

# N# `, n+ _: Q, f- j$ F6 Z8 o2 t
C.修改yarn-site.xml文件
使用以下命令修改gedit /home/joe/hadoop-3.0.0-alpha1/etc/hadoop/yarn-site.xml
在<configuration>标签之间插入以下内容
<property><name>yarn.resourcemanager.hostname</name><value>cMaster</value></property>
<property><name>yarn.nodemanager.aux-services</name><value>mapreduce_shuffle</value></property>
: |/ a. t# Q9 E/ f7 {! p
                               
登录/注册后可看大图

7 _  t7 }0 v3 `1 Z7 V
6 a5 z$ n& |9 j1 l% ~! k
D.修改mapred-site.xml.template
将/home/joe/hadoop-3.0.0-alpha1/etc/hadoop/目录下的mapred-site.xml.template重命名为mapred-site.xml
并用命令gedit/home/joe/hadoop-3.0.0-alpha1/etc/hadoop/mapred-site.xml
在<configuration>标签之间加入如下内容:
<property><name>mapreduce.framework.name</name><value>yarn</value></property>
2 b& R7 R6 k5 t
                               
登录/注册后可看大图
$ e- |: ]* X5 N7 @/ l5 k

! _% D7 C& R, K. U/ @. N. P' O
E.启动hadoop
首先格式化主节点命名空间,使用命令:
/home/joe/hadoop-3.0.0-alpha1/bin/hdfsnamenode –formate
其次在主节点上启动存储服务和资源管理主服务。使用命令:
/home/joe/hadoop-3.0.0-alpha1/sbin/hadoop-daemon.sh start namenode #启动主存储服务
/home/joe/hadoop-3.0.0-alpha1/sbin/yarn-daemon.sh start resourcemanager # 启动资源管理服务。
最后在从节点上启动存储从服务和资源管理从服务(以下两条命令要在两台机器上分别执行)
/home/joe/hadoop-3.0.0-alpha1/sbin/hadoop-daemon.sh start datanode #启动从存储服务
/home/joe/hadoop-3.0.0-alpha1/sbin/yarn-daemon.sh start nodemanager #启动资源管理从服务

  Y7 U" a6 r0 {                               
登录/注册后可看大图

2 Q; k. `- d  Z/ V& K& \* d/ n
" c' b  r. q! V# Z
服务启动后在三台机器上分别使用jps命令查看是否启动。
cSlave0和cSlave1如下图所示

: g5 \" D1 n6 R7 d$ g                               
登录/注册后可看大图
; L8 c0 x5 [; u0 W

9 _+ m. o9 M2 T" h/ F
cMaster节点显示如下图所示
1 `( b" e% {: x! F# \/ E. O
                               
登录/注册后可看大图

: K# \; ~; ~& h0 V
) X: _9 X3 x6 A; w3 w8 Y
在cMaster机器的浏览器地址栏里输入cMaster:50070可以看到HDFS的相关信息,cMaster:8088可以看到Yarn的相关信息。

, K/ W% ]3 |' x# s* \. V9 a$ z
如图还可以查看从节点的信息。

! S- {6 l6 m2 y: t6 r4 s                               
登录/注册后可看大图

- ^. N6 h1 z6 d4 F- {
& }" C+ Q" U& X( h( a* D/ V. s
至此 Hadoop3.0的配置工作已经完成了。接下来可以使用示例程序Wordcount来利用分布式系统统计某个文件中单词出现的次数。
在cMaster上以joe用户登录,然后执行以下的操作命令:
  cd/home/joe/hadoop-3.0.0-alpha1/
bin/hdfs dfs -mkdir /in
bin/hdfs dfs -put/home/joe/hadoop-3.0.0-alpha1/etc/hadoop/* /in
bin/hadoop jarshare/hadoop/mapreduce/hadoop-mapreduce-examples-3.0.0-alpha1.jar  wordcount /in /out/wc
如下图,在浏览器中输入cMaster:50070 可以看到hdfs,切换到相应文件夹下可以看到统计出的结果。

  y& x7 z. f/ J3 S" m                               
登录/注册后可看大图

2 G- w! E1 V4 `( t/ }0 c

2 U% o+ s  G/ y) A0 V% X

3 a/ d2 h9 f4 b8 d

1 Q, X$ }  k7 |, [" o
, _* J1 v. T6 U; r5 S
您需要登录后才可以回帖 登录 | 开始注册

本版积分规则

关闭

站长推荐上一条 /4 下一条

北京云银创陇科技有限公司以云计算运维,代码开发

QQ|返回首页|Archiver|小黑屋|易陆发现技术论坛 ( 蜀ICP备2026014127号-1 )点击这里给我发消息

GMT+8, 2026-4-9 01:02 , Processed in 0.063543 second(s), 24 queries .

Powered by Discuz! X3.4 Licensed

© 2012-2025 Discuz! Team.

快速回复 返回顶部 返回列表