具体可以参考Hadoop官网 http://hadoop.apache.org/docs/current/hadoop-project-dist/hadoop-common/SingleCluster.html 及 http://hadoop.apache.org/docs/current/hadoop-project-dist/hadoop-common/ClusterSetup.html
1. 安装前准备
需要安装对应的java和ssh及sshd
data:image/s3,"s3://crabby-images/30c1c/30c1c55c07bd5bd41a63c43786efeeaa1040f347" alt=""
Centos7下已经安装好了ssh及sshd,这里就不描述了。
java安装详见:http://www.jianshu.com/p/5d3ecf3b30f6
下面的例子都是安装的oracle的jdk8演示的。
java -version 查看是否配置安装成功:
data:image/s3,"s3://crabby-images/a6277/a62776f74ad63efa9cd1b9b4da69ec4f79e3b1a5" alt=""
2. 安装hadoop
从官网下载需要的版本,这里用的是当前最新的2.8.1。
用 tar -zxvf 进行解压。
在解压的目录下修改etc/hadoop/hadoop-env.sh,只需要修改对应的JAVA_HOME:
data:image/s3,"s3://crabby-images/78963/78963d85578bc549468a7e245cc4dfed177b065e" alt=""
可以看到一bin/hadoop目录的一些用法:
data:image/s3,"s3://crabby-images/f3c3f/f3c3f7908e44a8e1ad601a082de2826be7f41be4" alt=""
然后官网给出了3种安装方式(本地,伪分布式,分布式):
data:image/s3,"s3://crabby-images/08b55/08b55027de2183b96a691cfb93c4179f570baf42" alt=""
2.1 Local(Standalone) 本地模式
data:image/s3,"s3://crabby-images/3b702/3b702a8643f54a4935175d0f83582d1a7eb8df5b" alt=""
在安装hadoop的根目录运行:mkdir input
data:image/s3,"s3://crabby-images/3c43d/3c43df466c69457b4100e255ed914f457b78b892" alt=""
复制etc/hadoop下的xml文件到input文件夹:cp etc/hadoop/*.xml input
data:image/s3,"s3://crabby-images/61050/610504cff00046e6d1ea801d704390462c762c55" alt=""
运行hadoop的example,这里根据具体的hadoop版本来看(这里用的是2.8.1):bin/hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-2.8.1.jar grep input output 'dfs[a-z.]+'
data:image/s3,"s3://crabby-images/5dd97/5dd970880cc2cb31c2e040912a16dee17f1a5fa7" alt=""
这个例子应该是统计对应的文件夹下xml中有多少个'dfs[a-z.]+',然后输出结果到output。再次验证这个例子时需要用不同的输出文件夹,这里方便测试删除了output,运行bin/hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-2.8.1.jar grep input output 'xml+':
data:image/s3,"s3://crabby-images/c9854/c98544d4e3709cdcf7a648893d163f643f02e4c7" alt=""
在output文件加下有2个文件:
data:image/s3,"s3://crabby-images/fd539/fd539e7279fa3fdc84372e1a6292122b2a0c5de2" alt=""
其中part-r-00000记录了 ‘13 xml’。
2.2 Pseudo-Distributed 伪分布式
2.2.1 按照官网的说明进行配置修改:
data:image/s3,"s3://crabby-images/7ec81/7ec81fde3bb7af970bff8f0c680b0d248d2b5072" alt=""
修改etc/hadoop/core-site.xml文件(根据自己的域名进行修改,不一定是localhost,可能修改过了):vim etc/hadoop/core-site.xml
<configuration>
<property>
<name>fs.defaultFS</name>
<value>hdfs://localhost:9000</value>
</property>
<property>
<name>hadoop.tmp.dir</name>
<value>/usr/local/hadoop/hdfs/tmp</value>
</property>
<property>
<name>fs.trash.interval</name>
<value>4320</value>
</property>
</configuration>
修改etc/hadoop/hdfs-site.xml文件:vim etc/hadoop/hdfs-site.xml
<configuration>
<property>
<name>dfs.replication</name>
<value>3</value>
</property>
<property>
<name>dfs.namenode.name.dir</name>
<value>/usr/local/src/hadoop-2.8.1/hdfs/name</value>
</property>
<property>
<name>dfs.datanode.data.dir</name>
<value>/usr/local/src/hadoop-2.8.1/hdfs/data</value>
</property>
<property>
<name>dfs.webhdfs.enabled</name>
<value>true</value>
</property>
<property>
<name>dfs.permissions.superusergroup</name>
<value>staff</value>
</property>
<property>
<name>dfs.permissions.enabled</name>
<value>false</value>
</property>
</configuration>
2.2.2 按照官网的配置设置免密码登录:
data:image/s3,"s3://crabby-images/c2a7d/c2a7da53310b04e3e5b2b5ee11b6bc79640ab9db" alt=""
一般情况下是需要进行设置的(还是根据具体的域名和用户来进行设置):
$ ssh-keygen -t rsa -P '' -f ~/.ssh/id_rsa
$ cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
$ chmod 0600 ~/.ssh/authorized_keys
运行完上面的命令后进行检测:ssh localhost,发现不需要设置密码了。
2.2.3 运行mapreduce
参考官网进行配置:
data:image/s3,"s3://crabby-images/68ed9/68ed901857e310dbaf86b34af69098aefd01bb34" alt=""
首先格式化文件系统:bin/hdfs namenode -format
确定NameNode和DataNode的守护进程:sbin/start-dfs.sh
data:image/s3,"s3://crabby-images/7b0ce/7b0ce7f0279a3be0ebe8df743125c57bae37139d" alt=""
查看是否启动成功: jps
data:image/s3,"s3://crabby-images/22e11/22e11c86df266610c7daf638f058e2a4559edae9" alt=""
在web页面访问安装hadoop机器的ip(hadoop2.8.1的默认端口是50070,上图中的是3.X版本的文档,写的是默认端口9870):http://hadoopIp:50070
data:image/s3,"s3://crabby-images/8de14/8de14ae5460fda92378c655ebdb4ceed15f69c32" alt=""
创建HDFS文件夹来运行mapreduce任务
$ bin/hdfs dfs -mkdir /user
$ bin/hdfs dfs -mkdir /user/<username>
复制输入文件到分布式文件系统hdfs(这里创建的input不是当前hadoop根目录下的input)
$ bin/hdfs dfs -mkdir input
$ bin/hdfs dfs -put etc/hadoop/*.xml input
运行提供的例子(不是很明白这里和前面的操作有什么不同):bin/hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-2.8.1.jar grep input output 'dfs[a-z.]+'
检查输出文件:bin/hdfs dfs -cat output/*
测试完成,关闭守护进程:sbin/stop-dfs.sh
data:image/s3,"s3://crabby-images/73900/73900be2d6bba99fe3c8d20827d5168181aae0e6" alt=""
2.2.4 运行YARN
参考官网进行配置:
data:image/s3,"s3://crabby-images/80c0f/80c0f3226b6812080b045a8a28f0514b282728fe" alt=""
修改mapred-site.xml:vim etc/hadoop/mapred-site.xml
<configuration>
<property>
<name>mapreduce.framework.name</name>
<value>yarn</value>
</property>
</configuration>
修改yarn-site.xml(这里配置一个环节变量的白名单):vim etc/hadoop/yarn-site.xml
<configuration>
<property>
<name>yarn.nodemanager.aux-services</name>
<value>mapreduce_shuffle</value>
</property>
<property>
<name>yarn.nodemanager.env-whitelist</name>
<value>JAVA_HOME,HADOOP_COMMON_HOME,HADOOP_HDFS_HOME,HADOOP_CONF_DIR,CLASSPATH_PREPEND_DISTCACHE,HADOOP_YARN_HOME,HADOOP_MAPRED_HOME</value>
</property>
</configuration>
这里要修改环境变量设置,在末尾添加:
export HADOOP_HOME=/usr/local/src/hadoop-2.8.1/
export HADOOP_PREFIX=$HADOOP_HOME
export HADOOP_COMMON_HOME=$HADOOP_PREFIX
export HADOOP_CONF_DIR=$HADOOP_PREFIX/etc/hadoop
export HADOOP_HDFS_HOME=$HADOOP_PREFIX
export HADOOP_MAPRED_HOME=$HADOOP_PREFIX
export HADOOP_YARN_HOME=$HADOOP_PREFIX
export PATH=$PATH:$HADOOP_HOME/bin:$HADOOP_HOME/sbin:
启动ResourceManager和NodeManager守护进程:sbin/start-yarn.sh
data:image/s3,"s3://crabby-images/c4dad/c4dad46b1172389a42ba77f12f06edf3bc9c3d26" alt=""
在浏览器中查看ResourceManager的web页面:http://hadoopIp:8088
data:image/s3,"s3://crabby-images/fa872/fa8725bb43e5afe643e9f4ddf710952f443c7c63" alt=""
运行一个mapreduce的任务:
先启动dfs:bin/start-dfs.sh,
然后还是继续运行hadoop的example:bin/hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-2.8.1.jar grep input output 'dfs[a-z.]+' (这里暂时不知道运行结果是否正确,卡在这里没动;这是因为liunx的硬盘空间超过了90%,需要清理)
data:image/s3,"s3://crabby-images/710d2/710d2c85e387d7810aa98ebd596c150b6dea5270" alt=""
再次刷新检查ResourceManager的web页面,可以看到下方多了上图中运行的任务
data:image/s3,"s3://crabby-images/893a4/893a42f78cb1cf58dcf1cc6d30c7f662a76a3521" alt=""
测试完成,关闭Yarn的守护进程: sbin/stop-yarn.sh
2.3 集群配置
集群配置详见(根据对应的版本去查找,这里给的是最新的地址)http://hadoop.apache.org/docs/current/hadoop-project-dist/hadoop-common/ClusterSetup.html 。这里简单地介绍下基于前面搭建好的伪分布式进行搭建。
我们先按照1master,3个slave的方式来搭建;首先将搭建伪分布式hadoop的虚拟机复制3份,将机器的域名改成master, slave1, slave2和slave3.
下面提到的要修改的文件都是在hadoop根目录下的etc/hadoop下。
在所有的机器上修改core-site.xml (只要将原来的localhost全部改成master):
data:image/s3,"s3://crabby-images/82e9e/82e9e94a55da6b1966faabb166219bba3e33b261" alt=""
在master节点上修改hdfs-site.xml(只要添加dfs.namenode.secondary.http-address):
data:image/s3,"s3://crabby-images/0ea50/0ea50d9b2bfd12041d644078a7382ac120ca1f24" alt=""
在所有节点上修改mapred-site.xml(只要添加mapreduce.jobhistory.address和mapreduce.jobhistory.webapp.address):
data:image/s3,"s3://crabby-images/1f424/1f4243e907b22a2c93da3dcc4851b4ddb0e3b5dc" alt=""
jobhistory是 Hadoop自带了一个历史服务器,用于记录 Mapreduce历史作业。默认情况下, jobhistory没有启动,可用手动通过命令启动。
这里用的2.8.1的命令是:mapred historyserver。其他版本的需要查看相关文档。
所有节点修改yarn-site.xml(按照下图标红的添加):
data:image/s3,"s3://crabby-images/69e6f/69e6fc2e32c8d8216008dbeee1f9d870f94e1f02" alt=""
master节点修改slaves文件(每个slave域名都需要是独立的一行):
data:image/s3,"s3://crabby-images/6ae8e/6ae8e574674049cb6ef33076448c0cf713e079db" alt=""
不难发现集群配置的修改主要是把默认配置的localhost域名指向了master。
这里要重新运行格式化文件系统(如果hadoop根目录的hdfs/data下有内容,需要清理,避免造成前面搭建环境引起的问题):hdfs namenode -format
在master上运行start-dfs.sh:
data:image/s3,"s3://crabby-images/2c391/2c391a819b0c0f56dd38946f9cd93a6400d6509a" alt=""
在web页面进行查看:
data:image/s3,"s3://crabby-images/88fe9/88fe96e77fadd7529811c5f0f42fff33d53a452f" alt=""
在所有节点上运行jps查看:
data:image/s3,"s3://crabby-images/68f5b/68f5bd531245166477b258ff258d055722df86da" alt=""
可以发现master上只启动了NameNode和SecondaryNameNode,其他slave节点上只有DataNode启动。
在master上运行start-yarn.sh:
data:image/s3,"s3://crabby-images/0bafc/0bafc69550ee57b1e4a94786a97e72ea3d25c676" alt=""
在web页面查看cluster信息:
data:image/s3,"s3://crabby-images/07e8a/07e8ae5885f9fa732bf0dc078a1b0fed24e49cf9" alt=""
可以发现3个Node的信息了,在所有节点上运行jps:
data:image/s3,"s3://crabby-images/9948a/9948a6b268dee2316a13079797a18a4caae9afbc" alt=""
发现master上多了ResourceManager,其他slave上多了NodeManager。
最后在master上运行官网的例子,需要重新创建hdfs目录:
$ hdfs dfs -mkdir /user
$ hdfs dfs -mkdir /user/root
复制输入文件到分布式文件系统hdfs(这里创建的input不是当前hadoop根目录下的input)
$ hdfs dfs -mkdir input
$ hdfs dfs -put etc/hadoop/*.xml input
在hadoop根目录运行:bin/hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-2.8.1.jar grep input output 'dfs[a-z.]+'
查看输出结果:hdfs dfs -cat output/*
data:image/s3,"s3://crabby-images/401a7/401a7592046e018e4961a987c7718300abc1f8fb" alt=""
在集群的web页面查看:
data:image/s3,"s3://crabby-images/bcf02/bcf024d2a9a5546797f7c25ec65ffd952bfcf2e9" alt=""
要查看history需要先运行mapred historyserver:
data:image/s3,"s3://crabby-images/344db/344db0726c0b0a9de11510242a73aa6241d3461f" alt=""
点击集群web页面下的history链接,可以看具体的信息:
data:image/s3,"s3://crabby-images/3b6ab/3b6ab0e06e12349e88310a90cbaaef10789d8f61" alt=""
到这里应该表示集群都已经搭建好了,也可以通过web页面进行查看。
网友评论