Hadoop编译源码

1.1 前期准备工作

1)CentOS联网

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

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

2)jar包准备(hadoop源码、JDK8 、 maven、 ant 、protobuf)

(1)hadoop-2.7.6-src.tar.gz

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

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

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

(5)protobuf-2.5.0.tar.gz

1.2 jar包安装

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

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

[[email protected] software] # tar -zxf jdk-8u144-linux-x64.tar.gz -C /opt/module/

[[email protected] software]# vi /etc/profile


#JAVA_HOME

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

export PATH=$PATH:$JAVA_HOME/bin

[[email protected] software]#source /etc/profile

验证命令:java -version

2)Maven解压、配置  MAVEN_HOME和PATH。

[[email protected] software]# tar -zxvf apache-maven-3.0.5-bin.tar.gz -C /opt/module/

[[email protected] 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

[[email protected] software]#source /etc/profile

验证命令:mvn -version

3)ant解压、配置  ANT _HOME和PATH。

[[email protected] software]# tar -zxvf apache-ant-1.9.9-bin.tar.gz -C /opt/module/

[[email protected] 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

[[email protected] software]#source /etc/profile

验证命令:ant -version

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

[[email protected] apache-ant-1.9.9]# yum install glibc-headers

[[email protected] apache-ant-1.9.9]# yum install gcc-c++

5)安装make和cmake

[[email protected] apache-ant-1.9.9]# yum install make

[[email protected] apache-ant-1.9.9]# yum install cmake

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

然后相继执行命令:

[[email protected] software]# tar -zxvf protobuf-2.5.0.tar.gz -C /opt/module/

[[email protected] opt]# cd /opt/module/protobuf-2.5.0/

[[email protected]]#./configure

[[email protected] protobuf-2.5.0]# make

[[email protected] protobuf-2.5.0]# make check

[[email protected] protobuf-2.5.0]# make install

[[email protected] protobuf-2.5.0]# ldconfig

[[email protected]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

[[email protected] software]#source /etc/profile

验证命令:protoc --version

7)安装openssl库

[[email protected] software]#yum install openssl-devel

8)安装 ncurses-devel库:

[[email protected] software]#yum install ncurses-devel

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

1.3 编译源码

1)解压源码到/opt/目录

[[email protected] software]# tar -zxvf hadoop-2.7.6-src.tar.gz -C /opt/

2)进入到hadoop源码主目录

[[email protected] hadoop-2.7.6-src]# pwd

/opt/hadoop-2.7.6-src

3)通过maven执行编译命令

[[email protected] hadoop-2.7.6-src]#mvn package -Pdist,native -DskipTests -Dtar

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

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

[[email protected] target]# pwd

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

1.4 常见的问题解决方案

1)MAVEN install时候JVM内存溢出

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

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

[[email protected] hadoop-2.7.6-src]#mvn package -Pdist,native -DskipTests -Dtar

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

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

原文地址:https://www.cnblogs.com/frankdeng/p/9005923.html

时间: 2024-08-10 14:06:05

Hadoop编译源码的相关文章

大数据技术之_03_Hadoop学习_02_入门_Hadoop运行模式+【本地运行模式+伪分布式运行模式+完全分布式运行模式(开发重点)】+Hadoop编译源码(面试重点)+常见错误及解决方案

第4章 Hadoop运行模式4.1 本地运行模式4.1.1 官方Grep案例4.1.2 官方WordCount案例4.2 伪分布式运行模式4.2.1 启动HDFS并运行MapReduce程序4.2.2 启动YARN并运行MapReduce程序4.2.3 配置历史服务器4.2.4 配置日志的聚集4.2.5 配置文件说明4.3 完全分布式运行模式(开发重点)4.3.1 虚拟机准备4.3.2 编写集群分发脚本xsync4.3.3 集群配置4.3.4 集群单点启动4.3.5 SSH无密登录配置4.3.6

Hadoop HDFS源码分析 关于数据块的类

Hadoop HDFS源码分析 关于数据块的类 1.BlocksMap 官方代码中的注释为: /** * This class maintains the map from a block to its metadata. * block's metadata currently includes blockCollection it belongs to and * the datanodes that store the block. */ BlocksMap数据块映射,管理名字节点上的数据

【流媒体开发】VLC Media Player - Android 平台源码编译 与 二次开发详解 (提供详细800M下载好的编译源码及eclipse可调试播放器源码下载)

作者 : 韩曙亮  博客地址 : http://blog.csdn.net/shulianghan/article/details/42707293 转载请注明出处 : http://blog.csdn.net/shulianghan VLC 二次开发 视频教程 : http://edu.csdn.net/course/detail/355 博客总结 : -- 本博客目的 : 让 Android 开发者通过看本博客能够掌握独立移植 VLC Media Player 核心框架到自己的 app 中,

编译源码包httpd

前面介绍了rpm和yum,现在来介绍源码编译安装(高大上的感觉). 一.什么是编译安装 编译安装:就是把源代码转换为二进制,然后安装. 二.源码包去哪里下载,如何获得源码包                apache.org (ASF)                mariadb.org                SourceForge                Github.com                code.google.com 获得源码包 这样我们就获得了源码包,在编

ubuntu配置android开发环境和编译源码遇到的一些问题

---------------------------------------------环境变量设置--------------------------------------------- 1.设置jdk环境变量 编译android源码只支持jdk 1.6,所以如果需要编译源码必须下载jdk 1.6,不能下载最新的jdk 1.7,如果不需要编译源码则可以下载1.7版本的. 1.6版本jdk下载地址:http://www.oracle.com/technetwork/java/javase/d

CentOS 编译源码

编译python3为例: 1.下载源码包( 可能是.tar.gz, tar.bz2格式的,也可能是从git上下载) 2.得到源码包解压 源码文件:一般是.c .py 之类的 检测文件:名字一般是configure 软件安装和说明一般是INSTALL或README ( 里面一般会有安装流程 ) 3.到目录下 ./configure configure文件是一个script, 用来检测你的linux系统,相关的软件,以及系统的配置等,运行这个文件后,会生成一个名字为Makefile的文件. 4.  

【Linux学习】 写一个简单的Makefile编译源码获取当前系统时间

打算学习一下Linux,这两天先看了一下gcc的简单用法以及makefile的写法,今天是周末,天气闷热超市,早晨突然发现住处的冰箱可以用了,于是先出去吃了点东西,然后去超市买了一坨冰棍,老冰棍居多,5毛钱一根,还有几根1.5的. 嗯 接着说gcc的事 先把源代码贴上来 //gettime.h #ifndef _GET_TIME_H_ #define _GET_TIME_H_ void PrintCurrentTime(); #endif //gettime.c #include <stdio.

Ubuntu编译源码搭建PHP开发环境

准备源码: 1.mysql的源码:mysql-5.5.15.tar.gz 2.apache的源码:httpd-2.2.19.tar.gz 3.php的源码:php-5.3.6.tar.gz 第一步,安装MySql groupadd mysql                                添加一个mysql用户组useradd -g mysql mysql                  添加一个mysql到用户,此用户属于mysql组 tar -xzvf mysql-5.5.

LINUX下编译源码时所需提前安装的常用依赖包列表

yum -y install gcc gcc-c++ autoconf libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel curl -devel e2fsprogs e2fsprogs-de