Hadoop编译源码

1.1 前期准备工作

1CentOS联网

配置CentOS能连接外网。最好是用新克隆的虚拟机

注意:采用root角色编译,减少文件夹权限出现问题

2jar准备(hadoop源码、JDK8 mavenant protobuf)

1hadoop-2.7.6-src.tar.gz

2jdk-8u144-linux-x64.tar.gz

3apache-ant-1.9.9-bin.tar.gz

4apache-maven-3.0.5-bin.tar.gz

5protobuf-2.5.0.tar.gz

1.2 jar包安装

0注意:所有操作必须在root用户下完成

1)JDK解压、配置环境变量 JAVA_HOMEPATH,验证java-version(如下都需要验证是否配置成功)

[root@node1 software] # tar -zxf jdk-8u144-linux-x64.tar.gz -C /opt/module/

[root@node1 software]# vi /etc/profile

#JAVA_HOME

export JAVA_HOME=/opt/module/jdk1.8.0_144

export PATH=$PATH:$JAVA_HOME/bin

[root@node1 software]#source /etc/profile

验证命令:java -version

2)Maven解压、配置  MAVEN_HOMEPATH

[root@node1 software]# tar -zxvf apache-maven-3.0.5-bin.tar.gz -C /opt/module/

[root@node1 apache-maven-3.0.5]#  vi /etc/profile

#MAVEN_HOME

export MAVEN_HOME=/opt/module/apache-maven-3.0.5

export PATH=$PATH:$MAVEN_HOME/bin

[root@node1 software]#source /etc/profile

验证命令:mvn -version

3)ant解压、配置  ANT _HOMEPATH

[root@node1 software]# tar -zxvf apache-ant-1.9.9-bin.tar.gz -C /opt/module/

[root@node1 apache-ant-1.9.9]# vi /etc/profile

#ANT_HOME

export ANT_HOME=/opt/module/apache-ant-1.9.9

export PATH=$PATH:$ANT_HOME/bin

[root@node1 software]#source /etc/profile

验证命令:ant -version

4)安装  glibc-headers  g++  命令如下

[root@node1 apache-ant-1.9.9]# yum install glibc-headers

[root@node1 apache-ant-1.9.9]# yum install gcc-c++

5)安装makecmake

[root@node1 apache-ant-1.9.9]# yum install make

[root@node1 apache-ant-1.9.9]# yum install cmake

6)解压protobuf 进入到解压后protobuf主目录/opt/module/protobuf-2.5.0

然后相继执行命令:

[root@node1 software]# tar -zxvf protobuf-2.5.0.tar.gz -C /opt/module/

[root@node1 opt]# cd /opt/module/protobuf-2.5.0/

[root@node1protobuf-2.5.0]#./configure 

[root@node1 protobuf-2.5.0]# make 

[root@node1 protobuf-2.5.0]# make check 

[root@node1 protobuf-2.5.0]# make install 

[root@node1 protobuf-2.5.0]# ldconfig 

[root@node1 hadoop-dist]# vi /etc/profile

#LD_LIBRARY_PATH

export LD_LIBRARY_PATH=/opt/module/protobuf-2.5.0

export PATH=$PATH:$LD_LIBRARY_PATH

[root@node1 software]#source /etc/profile

验证命令:protoc –version

7)安装openssl

[root@node1 software]#yum install openssl-devel

8)安装 ncurses-devel库:

[root@node1 software]#yum install ncurses-devel

到此,编译工具安装基本完成。

1.3 编译源码

1解压源码到/opt/目录

[root@node1 software]# tar -zxvf hadoop-2.7.6-src.tar.gz -C /opt/

2)进入到hadoop源码主目录

[root@node1 hadoop-2.7.6-src]# pwd

/opt/hadoop-2.7.6-src

3)通过maven执行编译命令

[root@node1 hadoop-2.7.6-src]#mvn package -Pdist,native -DskipTests -Dtar

等待时间30分钟左右,最终成功是全部SUCCESS。

4成功的64hadoop包在/opt/hadoop-2.7.6-src/hadoop-dist/target下。

[root@node1 target]# pwd

/opt/hadoop-2.7.6-src/hadoop-dist/target

1.4 常见的问题解决方案

1)MAVEN install时候JVM内存溢出

处理方式:在环境配置文件和maven的执行文件均可调整MAVEN_OPTheap大小。(详情查阅MAVEN 编译 JVM调优问题,如:http://outofmemory.cn/code-snippet/12652/maven-outofmemoryerror-method

2)编译期间maven报错。可能网络阻塞问题导致依赖库下载不完整导致,多次执行命令(一次通过比较难):

[root@hadoop101 hadoop-2.7.6-src]#mvn package -Pdist,native -DskipTests -Dtar

3)antprotobuf等错误,插件下载未完整或者插件版本问题,最开始链接有较多特殊情况,同时推荐

2.7.0版本的问题汇总帖子   http://www.tuicool.com/articles/IBn63qf

 

简单的Linux命令笔记

ls -l 详细信息ls /dev/ -ls 很详细ls -a 显示隐藏ls -lh 方便看ls -lh –sort=size 按大小排序.开头的都是隐藏 cd /media/ 进入cd .. 上一级pwd 当前工...

Linux常用基本命令[find]用法(1)

find是个很强大的命令,用法很多。 作用:查找目录下的文件,同时也可以调用其他命令执行相应的操作 用法: find [选项] [路径][操作语句] find [-H] [-L] [-...

linux系统开机流程详解

今天,我们主要来谈谈计算机系统的启动流程,在此借用网络上的一张图来说明整个流程: 1、BIOS启动 BIOS是写入到主板上的一个韧体(韧体就是写入到硬件上的...

makefile中的一些参数说明

#obj = main.o sub.o add.o div.o mul.osrc = $(wildcard *.c) #搜索.c文件 可以加路径 obj = $(patsubst %.c, %.o, $(src))#字符匹配替换,将src中所有.c...

Linux下设置共享目录

Linux系统的文件或目录的共享功能是非常强大,而且是非常灵活的,其对权限的控制可以做到非常的细致,当然如果你是通过命令行方式进行设置的 话,那么对...

Linux 基础

Linux 系统启动过程: 内核引导 运行init 系统初始化 建立终端 用户登录 Linux 关机:Sync>shutdown>reboot>halt  不管重启系统还是关机系...