Eclipse 导入Hadoop 2.6.0 源码
1. 首先前往 官网(Hadoop 2.6 下载地址)上下载Hadoop的源码文件,并解压
2. 事先请确定已经安装好jdk以及maven(Maven安装教程 这是其他人写的一篇博文,保存profile后,记得source下)
3. 进入到hadoop-2.6.0-src/hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop 目录
可以看到有很多文件夹,找到ipc目录,在里面mkdir protobuf文件夹(还有一丢丢问题,这个后面解决)
4. 安装protobuf
下载地址 : http://pan.baidu.com/s/1pJlZubT 并解压
切换到protobuf文件夹,依次在终端下输入:
. / configure
make
make check
make install
全部执行完后再输入protoc - - version检查是否安装成功。
5. hadoop-2.6.0-src/hadoop-common-project/hadoop-common/src/test/java/org/apache/hadoop/io/serializer/avro/TestAvroSerialization.java显示找不到AvroRecord类
去grepcode下载2.5.0或者更高版本的。放到相应位置
6. cd到 hadoop-2.6.0-src/hadoop-maven-plugins 目录下 使用:mvn intall
7. cd到hadoop-2.6.0-src 目录下 使用mvn eclipse:eclipse -DskipTests
8. 在Eclipse中:File-Import-Existing Projects into Workspace 选择hadoop-2.6.0-src目录导入(推荐换一个workspace再导入,因为project的数目挺多的)
到了这一步,基本上已经没什么问题了,但是还有一些小问题,需要解决
可能遇到的问题:
1.org.apache.hadoop.ipc.protobuf 包下,可能是空包。
去grepcode上搜索TestProtos和TestRpcServiceProtos两个类,我遇到的情况是本地目录已经存在那两个文件,却没有导入。
没有上述两个类,会提示一大片的EmptyRequestProto之类的无法解析
2.会提示com.sum.tool或者javadoc包无法解析
右键选择buildpath -> configure build path -> library -> add library -> ire system 即可
3. hadoop-streaming 工程中的build path 有问题
把source中的hadoop-yarn-server-resourcemanager/conf删除掉,然后Link Source:源码根目录/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/conf
4. mac下发现classes.jar找不到的问题:
Exception in thread "main" java.lang.AssertionError: Missing tools.jar at: /Library/Java/JavaVirtualMachines/jdk1.7.0_45.jdk/Contents/Home/Classes/classes.jar. Expression: file.exists()
this is as the compiler needs a file named tools.jar but localted at classes.jar under dir Classes but found nothing.so u can do workaround:
解决办法:
cd $JAVA_HOME
mkdir Classes
cd Classes
ln -s ../lib/tools.jar classes.jar
附件:AvroRecord.java hadoop2.6版本
/**
* Autogenerated by Avro
*
* DO NOT EDIT DIRECTLY
*/
package org.apache.hadoop.io.serializer.avro;
@SuppressWarnings("all")
@org.apache.avro.specific.AvroGenerated
public class AvroRecord extends org.apache.avro.specific.SpecificRecordBase implements org.apache.avro.specific.SpecificRecord {
public static final org.apache.avro.Schema SCHEMA$ = new org.apache.avro.Schema.Parser().parse("{\"type\":\"record\",\"name\":\"AvroRecord\",\"namespace\":\"org.apache.hadoop.io.serializer.avro\",\"fields\":[{\"name\":\"intField\",\"type\":\"int\"}]}");
public static org.apache.avro.Schema getClassSchema() { return SCHEMA$; }
@Deprecated public int intField; /**
* Default constructor.
*/
public AvroRecord() {} /**
* All-args constructor.
*/
public AvroRecord(java.lang.Integer intField) {
this.intField = intField;
} public org.apache.avro.Schema getSchema() { return SCHEMA$; }
// Used by DatumWriter. Applications should not call.
public java.lang.Object get(int field$) {
switch (field$) {
case 0: return intField;
default: throw new org.apache.avro.AvroRuntimeException("Bad index");
}
}
// Used by DatumReader. Applications should not call.
@SuppressWarnings(value="unchecked")
public void put(int field$, java.lang.Object value$) {
switch (field$) {
case 0: intField = (java.lang.Integer)value$; break;
default: throw new org.apache.avro.AvroRuntimeException("Bad index");
}
} /**
* Gets the value of the 'intField' field.
*/
public java.lang.Integer getIntField() {
return intField;
} /**
* Sets the value of the 'intField' field.
* @param value the value to set.
*/
public void setIntField(java.lang.Integer value) {
this.intField = value;
} /** Creates a new AvroRecord RecordBuilder */
public static org.apache.hadoop.io.serializer.avro.AvroRecord.Builder newBuilder() {
return new org.apache.hadoop.io.serializer.avro.AvroRecord.Builder();
} /** Creates a new AvroRecord RecordBuilder by copying an existing Builder */
public static org.apache.hadoop.io.serializer.avro.AvroRecord.Builder newBuilder(org.apache.hadoop.io.serializer.avro.AvroRecord.Builder other) {
return new org.apache.hadoop.io.serializer.avro.AvroRecord.Builder(other);
} /** Creates a new AvroRecord RecordBuilder by copying an existing AvroRecord instance */
public static org.apache.hadoop.io.serializer.avro.AvroRecord.Builder newBuilder(org.apache.hadoop.io.serializer.avro.AvroRecord other) {
return new org.apache.hadoop.io.serializer.avro.AvroRecord.Builder(other);
} /**
* RecordBuilder for AvroRecord instances.
*/
public static class Builder extends org.apache.avro.specific.SpecificRecordBuilderBase<AvroRecord>
implements org.apache.avro.data.RecordBuilder<AvroRecord> { private int intField; /** Creates a new Builder */
private Builder() {
super(org.apache.hadoop.io.serializer.avro.AvroRecord.SCHEMA$);
} /** Creates a Builder by copying an existing Builder */
private Builder(org.apache.hadoop.io.serializer.avro.AvroRecord.Builder other) {
super(other);
} /** Creates a Builder by copying an existing AvroRecord instance */
private Builder(org.apache.hadoop.io.serializer.avro.AvroRecord other) {
super(org.apache.hadoop.io.serializer.avro.AvroRecord.SCHEMA$);
if (isValidValue(fields()[0], other.intField)) {
this.intField = data().deepCopy(fields()[0].schema(), other.intField);
fieldSetFlags()[0] = true;
}
} /** Gets the value of the 'intField' field */
public java.lang.Integer getIntField() {
return intField;
} /** Sets the value of the 'intField' field */
public org.apache.hadoop.io.serializer.avro.AvroRecord.Builder setIntField(int value) {
validate(fields()[0], value);
this.intField = value;
fieldSetFlags()[0] = true;
return this;
} /** Checks whether the 'intField' field has been set */
public boolean hasIntField() {
return fieldSetFlags()[0];
} /** Clears the value of the 'intField' field */
public org.apache.hadoop.io.serializer.avro.AvroRecord.Builder clearIntField() {
fieldSetFlags()[0] = false;
return this;
} @Override
public AvroRecord build() {
try {
AvroRecord record = new AvroRecord();
record.intField = fieldSetFlags()[0] ? this.intField : (java.lang.Integer) defaultValue(fields()[0]);
return record;
} catch (Exception e) {
throw new org.apache.avro.AvroRuntimeException(e);
}
}
}
}
参考资料:
1. 在mac中导入hadoop2.6.0源代码至eclipse教程
3. hadoop-2.6.0-src源码导入Eclipse
5. 百度知道:导入时可能遇到的错误以及解决办法 (请参考其他1条回答)
Eclipse 导入Hadoop 2.6.0 源码的更多相关文章
- eclipse导入java和android sdk源码,帮助文档
eclipse导入java和android sdk源码,帮助文档 http://blog.csdn.net/ashelyhss/article/details/37993261 JavaDoc集成到E ...
- 64位centos 下编译 hadoop 2.6.0 源码
64位os下为啥要编译hadoop就不解释了,百度一下就能知道原因,下面是步骤: 前提:编译源码所在的机器,必须能上网,否则建议不要尝试了 一. 下载必要的组件 a) 下载hadoop源码 (当前最新 ...
- 如何从Eclipse导入github上的项目源码
1.首先在github.com上申请一个账号,比如笔者的账号为puma0072.Eclipse需要安装egit插件,在Eclipse中选择help->Marketplace,在search中输入 ...
- 如何从Eclipse导入github上的项目源码--转载
[转载出处声明:hil2000的专栏] 1.首先在github.com上申请一个账号,比如笔者的账号为puma0072.Eclipse需要安装egit插件,在Eclipse中选择help->Ma ...
- spark最新源码下载并导入到开发环境下助推高质量代码(Scala IDEA for Eclipse和IntelliJ IDEA皆适用)(以spark2.2.0源码包为例)(图文详解)
不多说,直接上干货! 前言 其实啊,无论你是初学者还是具备了有一定spark编程经验,都需要对spark源码足够重视起来. 本人,肺腑之己见,想要成为大数据的大牛和顶尖专家,多结合源码和操练编程. ...
- Eclipse 导入 Hadoop 源码
1.准备工作 jdk: eclipse: Maven: libprotoc :https://developers.google.com/protocol-buffers/ hadoop:http:/ ...
- Eclipse导入Hadoop源码项目及编写Hadoop程序
一 Eclipse导入Hadoop源码项目 基本步骤: 1)在Eclipse新建一个java项目[hadoop-1.2.1] 2)将Hadoop压缩包解压目录src下的core,hdfs,mapred ...
- JMeter4.0源码导入Eclipse记录
参考: https://blog.csdn.net/yue530tomtom/article/details/77870233?locationNum=10&fps=1 1.准备jdk环境 下 ...
- Hadoop1.x目录结构及Eclipse导入Hadoop源码项目
这是解压hadoop后,hadoop-1.2.1目录 各目录结构及说明: Eclipse导入Hadoop源码项目: 注意:如果没有ant的包可以去网上下,不是hadoop里面的. 然后如果通过以上还报 ...
随机推荐
- ubuntu安装和查看已安装软件
说明:由于图形化界面方法(如Add/Remove... 和Synaptic Package Manageer)比较简单,所以这里主要总结在终端通过命令行方式进行的软件包安装.卸载和删除的方法. 一.U ...
- c# byte转docx
问题情境: docx文件放进resource中,再用程序读出来的时候是二进制数组. 解决办法: public string ByteConvertWord(byte[] data, string fi ...
- Opendarlight Carbon 安装
写在前面 目前最轻松的一次安装过程,感谢大翔哥的帮助. 安装过程 1.Zip包下载 找到Opendaylight官网,进入下载界面找到Carbon版本并下载. 2.Zip包解压 把这个zip压缩包解压 ...
- 在Asp.Net中使用Redis【本文摘自智车芯官网】
Redis安装 在安装之前需要获取Redis安装包.在这里我们就不详细介绍安装包的获取了.这里Redis-x64-3.2.100.zip安装包为例通过dos命令取安装.通过dos命令找到安装目录. 在 ...
- Windows Forms编程实战学习:第二章 欢迎使用Visual Studio
第二章 欢迎使用Visual Studio 1,AssemblyInfo文件 包含程序集的属性,向应用程序添加元数据 [assembly:<attribute>(<setting&g ...
- Ubuntu 16.04 LTS安装sogou输入法详解
http://blog.csdn.net/qq_21792169/article/details/53152700 最近开始学习linux 在安装输入法中遇到的一些问题,最终成功安装,也得益于网络上的 ...
- VisualStudio2013 代码查看优化 对齐线
http://jingyan.baidu.com/article/363872eccef5276e4ba16f91.html
- vue h render function & render select with options bug
vue h render function & render select with options bug https://github.com/xgqfrms/vue/issues/41 ...
- [LeetCode] Climbing Sairs
You are climbing a stair case. It takes n steps to reach to the top. Each time you can either climb ...
- dom变成jquery对象 先获取dom对象 然后通过$()转换成jquery对象
dom变成jquery对象 先获取dom对象 然后通过$()转换成jquery对象