由于cdh给出的hadoop的安装包并没有提供带C程序访问的接口,所以我们在使用本地库(本地库可以用来做压缩,以及支持C程序等等)的时候就会出问题,所以一般需要自己重新编译。
Linux:推荐内存4G或以上,64位操作系统,联网,关闭防火墙。
jdk1.7安装:并在/etc/profile中配置环境变量,编译这里选择jdk1.7。
maven安装:编译需要在maven环境下进行。配置maven环境变量。
maven仓库:为增加编译速度,可以提前下载maven仓库,并在maven配置文件中指定本地仓库路径,同时添加阿里云镜像地址。
findbugs:下载解压并配置环境变量。
依赖包:在线安装一些依赖包。
yum -y install autoconf automake libtool cmake
yum -y install ncurses-devel
yum -y install openssl-devel
yum -y install lzo-devel zlib-devel gcc gcc-c++
yum -y install -y bzip2-devel
安装protobuf :解压并编译。
安装snappy :下载地址 http://code.google.com/p/snappy/ ,解压并编译。
cdh源码准备:源码下载地址为:
http://archive.cloudera.com/cdh5/cdh/5/hadoop-2.6.0-cdh5.14.0-src.tar.gz
进入解压的cdh源码目录中,
cd /export/servers/hadoop-2.6.0-cdh5.14.0
支持snappy压缩方式编译:
mvn package -DskipTests -Pdist,native -Dtar -Drequire.snappy -e –X
编译成功后,进入该目录查看编译之后得到的文件:
cd /export/servers/hadoop-2.6.0-cdh5.14.0/hadoop-dist/target
注意:所有环境变量配置完成后应执行命令使其立即生效。可通过source命令。
source /etc/profile
集群环境以三台虚拟机为例,分别命名为node01,node02,node03。
每台应提前安装jdk1.8并配置环境变量。
其他相关虚拟机安装配置可以参考其他文档。
下载地址为:
http://archive.cloudera.com/cdh5/cdh/5/
选择和编译的CDH相同的版本,这里为CDH5.14.0
创建zk数据存放目录
mkdir -p /export/servers/zookeeper-3.4.5-cdh5.14.0/zkdatas
修改zk配置文件
cd /export/servers/zookeeper-3.4.5-cdh5.14.0/conf
cp zoo_sample.cfg zoo.cfg
vim zoo.cfg
修改zoo.cfg中的内容:
dataDir=/export/servers/zookeeper-3.4.5-cdh5.14.0/zkdatas
autopurge.snapRetainCount=3
autopurge.purgeInterval=1
server.1=node01:2888:3888
server.2=node02:2888:3888
server.3=node03:2888:3888
在zkdatas中创建myid文件并写入内容:
echo 1 > /export/servers/zookeeper-3.4.5-cdh5.14.0/zkdatas/myid
将安装包分发到其他机器,并需要修改其他机器的myid.myid是zookeeper选取leader的重要信息。
可修改node02的myid为2,修改node03的myid为3.
三台机器均执行以下命令:
cd /export/servers/zookeeper-3.4.5-cdh5.14.0
bin/zkServer.sh start
安装环境服务部署规划,这里:
192.168.52.100为node01
192.168.52.110为node02
192.168.52.120为node03
服务器IP | 192.168.52.100 | 192.168.52.110 | 192.168.52.120 |
---|---|---|---|
HDFS | NameNode | – | – |
HDFS | SecondaryNameNode | – | – |
HDFS | DataNode | DataNode | DataNode |
YARN | ResourceManager | – | – |
YARN | NodeManager | NodeManager | NodeManager |
MapReduce | JobHistoryServer | – | – |
将我们重新编译之后支持snappy压缩的hadoop包上传到第一台服务器(指我的node01服务器,下同)并解压
第一台机器执行以下命令
cd /export/softwares/
tar -zxvf hadoop-2.6.0-cdh5.14.0.tar.gz -C ../servers/
第一台机器执行以下命令
cd /export/servers/hadoop-2.6.0-cdh5.14.0
bin/hadoop checknative
如果出现openssl为false,那么所有机器在线安装openssl即可
yum -y install openssl-devel
建议可以通过nodepad++进行连接服务器,然后进行编写修改配置文件,以避免vim模式下可能出现的拼写错误。
第一台机器执行以下命令
----1 修改core-site.xml
cd /export/servers/hadoop-2.6.0-cdh5.14.0/etc/hadoop
vim core-site.xml
更改文档信息:
fs.default.name
hdfs://192.168.52.100:8020
hadoop.tmp.dir
/export/servers/hadoop-2.6.0-cdh5.14.0/hadoopDatas/tempDatas
io.file.buffer.size
4096
fs.trash.interval
10080
----2 修改hdfs-site.xml
cd /export/servers/hadoop-2.6.0-cdh5.14.0/etc/hadoop
vim hdfs-site.xml
更改文档信息:
dfs.namenode.secondary.http-address
node01:50090
dfs.namenode.http-address
node01:50070
dfs.namenode.name.dir
file:///export/servers/hadoop-2.6.0-cdh5.14.0/hadoopDatas/namenodeDatas
dfs.datanode.data.dir
file:///export/servers/hadoop-2.6.0-cdh5.14.0/hadoopDatas/datanodeDatas
dfs.namenode.edits.dir
file:///export/servers/hadoop-2.6.0-cdh5.14.0/hadoopDatas/dfs/nn/edits
dfs.namenode.checkpoint.dir
file:///export/servers/hadoop-2.6.0-cdh5.14.0/hadoopDatas/dfs/snn/name
dfs.namenode.checkpoint.edits.dir
file:///export/servers/hadoop-2.6.0-cdh5.14.0/hadoopDatas/dfs/nn/snn/edits
dfs.replication
3
dfs.permissions
false
dfs.blocksize
134217728
----3 修改 hadoop-env.sh
cd /export/servers/hadoop-2.6.0-cdh5.14.0/etc/hadoop
vim hadoop-env.sh
更改文档信息:
export JAVA_HOME=/export/servers/jdk1.8.0_141
----4 修改 mapred-site.xml
cd /export/servers/hadoop-2.6.0-cdh5.14.0/etc/hadoop
vim mapred-site.xml
更改文档信息:
mapreduce.framework.name
yarn
mapreduce.job.ubertask.enable
true
mapreduce.jobhistory.address
node01:10020
mapreduce.jobhistory.webapp.address
node01:19888
----5 修改yarn-site.xml
cd /export/servers/hadoop-2.6.0-cdh5.14.0/etc/hadoop
vim yarn-site.xml
更改文档信息:
yarn.resourcemanager.hostname
node01
yarn.nodemanager.aux-services
mapreduce_shuffle
yarn.log-aggregation-enable
true
yarn.log-aggregation.retain-seconds
604800
----6 修改slaves文件
cd /export/servers/hadoop-2.6.0-cdh5.14.0/etc/hadoop
vim slaves
更改文档信息:
node01
node02
node03
注意:这里是所有搭建集群所用的服务器主机名。在前期Linux环境安装时,有对主机名起别名为node01、node02、node03
node01机器上面创建以下目录
mkdir -p /export/servers/hadoop-2.6.0-cdh5.14.0/hadoopDatas/tempDatas
mkdir -p /export/servers/hadoop-2.6.0-cdh5.14.0/hadoopDatas/namenodeDatas
mkdir -p /export/servers/hadoop-2.6.0-cdh5.14.0/hadoopDatas/datanodeDatas
mkdir -p /export/servers/hadoop-2.6.0-cdh5.14.0/hadoopDatas/dfs/nn/edits
mkdir -p /export/servers/hadoop-2.6.0-cdh5.14.0/hadoopDatas/dfs/snn/name
mkdir -p /export/servers/hadoop-2.6.0-cdh5.14.0/hadoopDatas/dfs/nn/snn/edits
这些目录用于后期hadoop 的namenode和datanodes等相关数据的生成存放目录。
这些目录在之前配置文件中均有配置。
集群初始化时,以及集群运行过程中的一些文件均会生成在我们配置的该目录中。
将第一台安装的hadoop安装包复制到其他机器
cd /export/servers/
scp -r hadoop-2.6.0-cdh5.14.0/ node02:$PWD
scp -r hadoop-2.6.0-cdh5.14.0/ node03:$PWD
集群所有机器都要配置hadoop环境变量。
vim /etc/profile
添加以下内容:
可直接在java环境变量后面添加:
export HADOOP_HOME=/export/servers/hadoop-2.6.0-cdh5.14.0
export PATH=:$HADOOP_HOME/bin:$HADOOP_HOME/sbin:$PATH
使配置文件立即生效
source /etc/profile
要启动 Hadoop 集群,需要启动 HDFS 和 YARN 两个集群。
注意:首次启动HDFS时,必须对其进行格式化操作。本质上是一些清理和准备工作,因为此时的 HDFS 在物理上还是不存在的。
bin/hadoop namenode –format
该指令会使集群在hadoopDatas中生成各种相关信息文件:如NameNode和DataNode中均会有VERSION文件,其中包含clusterId,namespaceID,
例如node01中:/export/servers/hadoop-2.6.0-cdh5.14.0/hadoopDatas/namenodeDatas/current
中namenode的VERSION文件内容如下:
namespaceID=715801864
clusterID=CID-8bdf2026-329e-4439-8016-55226cabfe84
cTime=0
storageType=NAME_NODE
blockpoolID=BP-1994706638-192.168.52.100-1535458650778
layoutVersion=-60
/export/servers/hadoop-2.6.0-cdh5.14.0/hadoopDatas/datanodeDatas/current 文件夹中datanode的VERSION文件格式如下:
storageID=DS-4a271b03-a87d-4069-a9a6-9782bac356c8
clusterID=CID-8bdf2026-329e-4439-8016-55226cabfe84
cTime=0
datanodeUuid=4d86a001-71e7-4d13-8fbd-898619fea804
storageType=DATA_NODE
layoutVersion=-56
注意: 格式化操作应只在集群环境刚配置完第一次启动前进行。后续集群启动均不用再进行格式化。
如果在第二次及以后启动集群前进行格式化,会导致namenode中的clusterID发生改变,此时与DataNode中VERSION文件的clusterID不一致,会导致DataNode无法正常启动。
如果配置了 etc/hadoop/slaves 和 ssh 免密登录,则可以使用程序脚本启动所有Hadoop 两个集群的相关进程,在主节点所设定的机器上执行即可。
node01节点上执行以下命令启动集群:
cd /export/servers/hadoop-2.6.0-cdh5.14.0/
sbin/start-dfs.sh
sbin/start-yarn.sh
sbin/mr-jobhistory-daemon.sh start historyserver
一键停止集群(友情提醒:生产环境下停止集群要慎重):
sbin/stop-dfs.sh
sbin/stop-yarn.sh
sbin/mr-jobhistory-daemon.sh start historyserver
在主节点上使用以下命令启动 HDFS NameNode:
hadoop-daemon.sh start namenode
在每个从节点上使用以下命令启动 HDFS DataNode:
hadoop-daemon.sh start datanode
在主节点上使用以下命令启动 YARN ResourceManager:
yarn-daemon.sh start resourcemanager
在每个从节点上使用以下命令启动 YARN nodemanager:
yarn-daemon.sh start nodemanager
以上脚本位于$HADOOP_PREFIX/sbin/目录中。如果想要停止某个节点上某个角色,只需要把命令中的start 改为stop 即可。
hdfs集群访问地址(或者直接输入node01:50070)
http://192.168.52.100:50070/dfshealth.html#tab-overview
yarn集群访问地址
http://192.168.52.100:8088/cluster
jobhistory访问地址:
http://192.168.52.100:19888/jobhistory
如对文中有任何疑问,欢迎及时交流。
共同学习,共同进步。