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里面的. 然后如果通过以上还报 ...
随机推荐
- Hybrid APP基础篇(四)->JSBridge的原理
说明 JSBridge实现原理 目录 前言 参考来源 前置技术要求 楔子 原理概述 简介 url scheme介绍 实现流程 实现思路 第一步:设计出一个Native与JS交互的全局桥对象 第二步:J ...
- Linux java项目冲突不能正常运行
部署项目,在windows环境部署到Tomcat能够正常运行,部署到Linux环境下只能访问一些html资源,不能正常运行. 解决步骤: 1.清除webapps目录下所有文件夹,将war包上传至web ...
- c# apache服务器请求得到数据(初级)
1.代码: string data = new WebClient().DownloadString("http://localhost:81/123.txt");
- TCP系列48—拥塞控制—11、FRTO拥塞撤销
一.概述 FRTO虚假超时重传检测我们之前重传章节的文章已经介绍过了,这里不再重复介绍,针对后面的示例在说明两点 1.FRTO只能用于虚假超时重传的探测,不能用于虚假快速重传的探测. 2.延迟ER重传 ...
- (十一)Jmeter另一种调试工具 HTTP Mirror Server
之前我介绍过Jmeter的一种调试工具Debug Sampler,它可以输出Jmeter的变量.属性甚至是系统属性而不用发送真实的请求到服务器.既然这样,那么HTTP Mirror Server又是做 ...
- Tomcat指定JDK路径
一.应用实例 一般情况下一台服务器只跑一个业务,那么就直接配置一套环境,设置好Java环境变量即可.某些时候一台服务器上会安装多个业务,而且各个业务需要的JDK版本各不相同,或者为了使业务独立开来,需 ...
- 微信小程序 功能函数 地图定位相对直线距离
GetDistance:function(lat1, lng1, lat2, lng2){ // console.log(lat1) var radLat1 = lat1 * Math.PI / ...
- 使用fabric1.14.0和fabric2.4.0
fabric1.14.0(支持Python2.5-2.7版本): from fabric.api import * env.gateway = '192.168.181.2' ...
- PHP面向对象之接口
接口(interface)技术 什么是接口? 先看抽象类: abstract class 类名 { 属性1: 属性2: ..... 非抽象方法1: 非抽象方法2: ...... 抽象方法1: 抽 ...
- Thread的run()与start()的区别
java的线程是通过java.lang.Thread类来实现的.VM启动时会有一个由主方法所定义的线程.可以通过创建Thread的实例来创建新的线程.每个线程都是通过某个特定Thread对象所对应的方 ...