花花世界蕾 发表于 2018-10-31 06:10:56

在eclipse3.7中配置hadoop1.0.1插件

  1.安装插件
  准备程序:
  eclipse-3.7
  hadoop-eclipse-plugin-1.0.1
  (http://download.csdn.net/detail/xiaoping8411/4216102)
  将hadoop-eclipse-plugin-1.0.1复制到eclipse/plugins目录下,重启eclipse。
  2.打开MapReduce视图
  Window-> Open Perspective -> Other 选择Map/Reduce,图标是个蓝色的象。
  3.添加一个MapReduce环境
  在eclipse下端,控制台旁边会多一个Tab,叫“Map/ReduceLocations”,在下面空白的地方点右键,选择“NewHadoop location...”,如图所示:
  在弹出的对话框中填写如下内容:
  Locationname(取个名字)
  Map/Reduce Master(JobTracker的IP和端口,根据mapred-site.xml中配置的mapred.job.tracker来填写)
  DFS Master(NameNode的IP和端口,根据core-site.xml中配置的fs.default.name来填写)
  Username:用户名(默认操作系统用户名,这个没什么用)
  4.使用eclipse对HDFS内容进行修改
  经过上一步骤,左侧“Project Explorer”中应该会出现配置好的HDFS,点击右键,可以进行新建文件夹、删除文件夹、上传文件、下载文件、删除文件等操作。
  注意:每一次操作完在eclipse中不能马上显示变化,必须得刷新一下。
  5.创建MapReduce工程
  5.1配置Hadoop路径
  Window-> Preferences 选择“Hadoop Map/Reduce”,点击“Browse...”选择Hadoop文件夹的路径。
  这个步骤与运行环境无关,只是在新建工程的时候能将hadoop根目录和lib目录下的所有jar包自动导入。
  5.2创建工程
  File-> New -> Project 选择“Map/ReduceProject”,然后输入项目名称,创建项目。插件会自动把hadoop根目录和lib目录下的所有jar包导入。
  5.3创建Mapper或者Reducer
  File-> New -> Mapper 创建Mapper,自动继承mapred包里面的MapReduceBase并实现Mapper接口。
  注意:这个插件自动继承的是mapred包里旧版的类和接口,新版的Mapper得自己写。
  Reducer同理。
  6.在eclipse中运行WordCount程序
  6.1导入WordCount
  从hadoop自带的hadoop-examples-1.0.1.jar中获取WordCount程序
  6.2配置运行参数
  Run As-> Open Run Dialog... 选择WordCount程序,在Arguments中配置运行参数:/mapreduce/wordcount/input/mapreduce/wordcount/output/1
  分别表示HDFS下的输入目录和输出目录,其中输入目录中有几个文本文件,输出目录必须不存在。
  6.3运行
  Run As-> Run on Hadoop 选择之前配置好的MapReduce运行环境,点击“Finish”运行。
  控制台会输出相关的运行信息。
  6.4查看运行结果
  在输出目录/mapreduce/wordcount/output/1中,可以看见WordCount程序的输出文件。除此之外,还可以看见一个logs文件夹,里面会有运行的日志。
  7 常见问题:
  7.1 目录权限认证问题,问题如下:
  12/04/1111:41:46 ERROR security.UserGroupInformation: PriviledgedActionExceptionas:lzpcause:java.io.IOException:Failed to set permissions of path:\app\hadoop\hadoop-1.0.1\hadoopdata\mapred\staging\lzp1107758487\.staging to0700
  Exceptionin thread "main" java.io.IOException:Failed to set permissions of path:\app\hadoop\hadoop-1.0.1\hadoopdata\mapred\staging\lzp1107758487\.staging to0700
  atorg.apache.hadoop.fs.FileUtil.checkReturnValue(FileUtil.java:682)
  atorg.apache.hadoop.fs.FileUtil.setPermission(FileUtil.java:655)
  解决方法:
  这个问题用该是windows这边的问题,其中\app\hadoop\hadoop-1.0.1\hadoopdata\mapred\staging\lzp11是windows7磁盘上的一个目录
  网上查到这是由于0.20.203.0以后的版本的权限认证引起的,只有去掉才行
  修改hadoop源代码,去除权限认证,修改FileUtil.java的checkReturnValue方法,如下:
  privatestatic void checkReturnValue(boolean rv, File p,
  FsPermissionpermission
  ) throws IOException {
  // if(!rv) {
  //throw new IOException("Failed to set permissions of path: " + p +
  //" to " +
  //String.format("%04o", permission.toShort()));
  // }
  }

页: [1]
查看完整版本: 在eclipse3.7中配置hadoop1.0.1插件