windows eclipse运行mapreduce遇到权限问题该如何解决



根据 hadoop开发方式总结及操作指导


采用第一种开发方式,我们会遇到权限问题,面对这个问题,该如何解决,有两种解决办法:

第一种解决办法:
1、重新编译hadoop-core-xxx.jar包1. 原因 当用hadoop中自带的hadoop-core-xxx.jar包时,会出现UserGroupInformation类型的错误,这个是Windows下文件权限问题,在Linux下可以正常运行。 
2. 解决方案 修改/hadoop-xxx/src/core/org/apache/hadoop/fs/FileUtil.java里的checkReturnValue,注释掉其中代码即可,重新编译后替换原hadoop-core-xxx.jar包中FileUtil.java,再替换掉hadoop-xxx根目录下的hadoop-core-xxx.jar即可。
修改前:

  1. private static void checkReturnValue(boolean rv, File p, 
  2. FsPermission permission
  3. ) throws IOException {
  4. if (!rv) {
  5. throw new IOException("Failed to set permissions of path: " + p + 
  6. " to " + 
  7. String.format("%04o", permission.toShort()));
  8. }
  9. }
复制代码
修改后:


  1. private static void checkReturnValue(boolean rv, File p, 
  2. FsPermission permission
  3. ) throws IOException {

  4. }
复制代码
被修改后FileUtil.java文件
  FileUtil.zip (6.41 KB, 下载次数: 2) 

第二种解决办法:将下面附件中的文件拖入项目中,与源码中的core包发生冲突,不过不影响运行
 org.zip (6.99 KB, 下载次数: 0) 
 


 





  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值