Maven编译32位Hadoop2.7.1

一、安装jdk7

在网上下载jdk7的包

解压缩jdk7的包

修改环境变量:

nano /etc/profile

在最后加上

#set java environment

export JAVA_HOME=解压目录

export JRE_HOME= ${JAVA_HOME}/jre    

export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib    

export PATH=${JAVA_HOME}/bin:$PATH

source /etc/profile

配置默认JDK:

update-alternatives --install /usr/bin/java java 目录/bin/java 300

update-alternatives --install /usr/bin/javac javac 目录/bin/javac 300

update-alternatives --install /usr/bin/javajavah 目录/bin/javah 300

update-alternatives --install /usr/bin/jar jar 目录/bin/jar 300


切换默认JDK:

update-alternatives --config java

update-alternatives --config javac

最后测试:

java -version

javac -version


二、安装maven

apt-get install maven

mvn --version


三、安装依赖库

apt-get install g++ autoconf automake libtool cmake zlib1g-dev pkg-config libssl-dev


四、安装openssh

apt-get install openssh-server

五、安装protoc

这里不能apt-get安装,因为安装的是2.6.1版本,而编译要求为2.5.0版本,所以只能从网上下载手动安装,下载地址:

http://f.dataguru.cn/forum.php?mod=attachment&aid=MTU2ODgzfDdmYzYxM2YzfDE0NTAxMDMwMzJ8MHw0NTI5OTE%3D

解压后进入目录

./configure --prefix=/usr/protobuf/

make && make install

之后/etc/profile中加入export PATH=/usr/protobuf/bin:$PATH

protoc --version 显示为2.5.0则成功

六、开始编译:

注意:开始编译前最好先设置maven的镜像地址,因为原地址真的太。。。

nano /etc/share/maven/conf/settings.xml

在<mirrors></mirrors>中加入

<mirror>

<id>UK</id>

<name>UK central</name>

<url>http://uk.maven.org/maven2/</url>

<mirrorOf>central</mirrorOf>

</mirror>

感觉这个镜像还比较靠谱。。。

注意:编译中可能会出现"java.lang.OutOfMemoryError: Java heap space"错误,这错误编译是给JVM分配的Xmx不够,但是在Maven中直接在mvn命令行后指定-Xmx1024m是不起作用的,需要在编译前设置Maven环境参数:

export MAVEN_OPTS='-Xms256m -Xmx1024m'

之后可以开始编译,进入hadoop源码目录hadoop-2.7.1-src

mvn clean

mvn package -Pdist,native -DskipTests=true -Dtar

之后等待编译完成

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JDK1.7新特性介绍 1. 对Java集合(Collections)的增强支持 在JDK1.7之前的版本中,Java集合容器中存取元素的形式如下: 以List、Set、Map集合容器为例: // 创建List接口对象 List<String> list = new ArrayList<String>(); list.add("item") String item = list.get(0); // 创建Set接口对象 Set<String> set = new HashSet<String>(); set.add("item"); // 创建map接口对象 Map<String, Integer> map = new HashMap<String, Integer>(); map.put("item", 1); int val = map.get("item");12345678910111213 在JDK1.7中,摒弃了Java集合接口的实现类,如:ArrayList、HashSet和HashMap。而是直接采用[]、{}的形式存入对象,采用[]的形式按照索引、键值来获取集合中的对象,如下: List<String> list = ["item"]; // 向List集合里面添加元素 String item = list[0]; Set<String> set = {"item"}; // 向Set集合里面添加元素 Map<String, Integer> map = {"item", 1}; // 向map集合里面添加元素 int val = map{"item"};1234567 2. 在Switch中可用String String s = ... switch(s) { case "item1": process1(); case "item2": process2(); break; . . . default: processn(); break; }1234567891011121314 3. 数值可加下划线 例如:int one_million = 1_000_000; 4. 支持二进制文字 例如:int binary = 0b1001_1001; 5. 简化了可变参数方法的调用 当程序员试图使用一个不可具体化的可变参数并调用一个varargs (可变)方法时,编辑器会生成一个“非安全操作”的警告。 --------------------- 本文来自 烦人的萝卜籽 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/jiangliwe/article/details/76026546?utm_source=copy

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值