hadoop分布式集群完全安装(非HA)

一、各节点基础环境配置(最好每台都配置)

先输入su获取root权限

1修改主机名

输入vim /etc/sysconfig/network

改成: NETWORKING=yes

HOSTNAME=myhostname

备注:myhostname是主机名,最好别都取成一样

 

2修改IP

     方法一图形界面修改

方法二

输入:vim /etc/sysconfig/network-scripts

改成: DEVICE="eth0"

BOOTPROTO="static"               ###

HWADDR="00:0C:29:3C:BF:E7"

IPV6INIT="yes"

NM_CONTROLLED="yes"

ONBOOT="yes"

TYPE="Ethernet"

UUID="ce22eeca-ecde-4536-8cc2-ef0dc36d4a8c"

IPADDR="192.168.1.101"           ###

NETMASK="255.255.255.0"          ###

GATEWAY="192.168.1.1"            ###

备注:所有主机在一个局域网,通过IPADDR,NETMASK的设置实现的。PADDR前三段设成一样的,最后一段1~255随便取,别重复就行。

3修改主机名与IP的映射关系

输入:vim  /etc/hosts

改成:

192.168.1.1  node1

192.168.1.2  node2

192.168.1.3  node3

192.168.1.4  node4

192.168.1.5  node5

备注:有多少主机就写多少个

4关闭防火墙

关闭防火墙开机启动

输入:chkconfig iptables off

查看防火墙开机启动状态

输入:chkconfig iptables --list

5重启linux

输入:reboot

二、配置ssh免密码登录

使用secureCRT远程操作配置好环境的主机,以下操作(二、三、四)都在secureCRT中进行

cd  /.ssh

ssh-keygen -t rsa (四个回车)

执行完这个命令后,会生成两个文件id_rsa(私钥)、id_rsa.pub(公钥)

在.ssh目录下创建authorized_keys文件, 把所有的公钥追加这个文件中。每个机器.ssh文件夹下放一份authorized_keys(这个文件的权限要改成可读可写)

追加语句:cat   id_rsa.pub >> authorized_keys

远程拷贝: scp  authorized_keys  CentOS:/home/hadoop/.shh

三、安装JDK

1上传alt+p 后出现sftp窗口,然后put d:\xxx\yy\ll\jdk-7u_65-i585.tar.gz

注意:安装的包的位数的和系统的位数一只

2解压jdk

#创建文件夹

mkdir  /home/hadoop/app

#解压

tar -zxvf jdk-7u55-linux-i586.tar.gz -C /home/hadoop/app

3将java添加到环境变量中

vim /etc/profile

#在文件最后添加

export JAVA_HOME=/home/hadoop/app/jdk-7u_65-i585

export PATH=$PATH:$JAVA_HOME/bin

#刷新配置

source /etc/profile

四、安装hadoop

1上传hadoop安装包

参考jdk的上传

2解压hadoop安装包

解压到/app/目录下

tar  -zxvf  hadoop-2.2.0.tar.gz  -C  /home/hadopp/app/

3修改配置文件(5个)

第一个:hadoop-env.sh

vim hadoop-env.sh

#第27行

export JAVA_HOME=/home/hadoop/app/jdk1.7.0_65

第二个:core-site.xml

<!-- 指定HADOOP所使用的文件系统schema(URI),

HDFS的老大(NameNode)的地址 -->

<property>

<name>fs.defaultFS</name>

<value>hdfs://CentOS1:9000</value>

</property>

<!-- 指定hadoop运行时产生文件的存储目录 ,

如果这个data文件不存在要自己创建-->

<property>

<name>hadoop.tmp.dir</name>

<value>/home/hadoop/hadoop-2.4.1/data</value>

</property>

第三个:hdfs-site.xml

<!-- 指定HDFS副本的数量 -->

<property>

<name>dfs.replication</name>

<value>2</value>

</property>

第四个:mapred-site.xml.template

vim mapred-site.xml.template

<!-- 指定mr运行在yarn上 -->

<property>

<name>mapreduce.framework.name</name>

<value>yarn</value>

</property>

第五个:yarn-site.xml

<!-- 指定YARN的老大(ResourceManager)的地址 -->

<property>

<name>yarn.resourcemanager.hostname</name>

<value>CentOS1</value>

</property>

<!-- reducer获取数据的方式 -->

<property>

<name>yarn.nodemanager.aux-services</name>

<value>mapreduce_shuffle</value>

</property>

第六个:slaves 指定datanode节点

Vim slaves

写入所有datanode节点名称

CentOS2

CentOS3

CentOS4

CentOS5

CentOS6

4将hadoop添加到环境变量,方便敲hadoop的命令

vim /etc/proflie

export JAVA_HOME=/home/hadoop/app/jdk1.7.0_65

export HADOOP_HOME=/home/hadoop/app/hadoop-2.4.1

export PATH=$PATH:$JAVA_HOME/bin:$HADOOP_HOME/bin:$HADOOP_HOME/sbin

保存后执行:source /etc/profile

5将配置好的app下的文件远程拷贝到其他的机器上

scp -r  app  centos2:/home/hadoop

6格式化HDFS(namenode)第一次使用时要格式化

hadoop namenode -format

7启动hadoop

先启动HDFS

start-dfs.sh

再启动YARN

start-yarn.sh

也可 start-all.sh

使用jps命令验证

27408 NameNode

28218 Jps

27643 SecondaryNameNode

28066 NodeManager

27803 ResourceManager

27512 DataNode

http://192.168.1.1:50070 (HDFS管理界面)

http://192.168.1.1:8088 (MR管理界面)

作者:dhhsmgj@Gmail.com

上一篇:mooc上学习acllib后写的包含背景音乐的小涂鸦板(初入江湖,大佬勿喷)


下一篇:opencv-jni -调试出错taking address of temporary [-fpermissive]