MapReduce在本地集群模式下运行debug

第一步:设置hadoop的在Window下运行配置

A、将hadoop(windows平台下编译的hadoop,注意版本)安装包解压一份到windows的任意一个目录下(注意我的安装包下

已经有winutils.exe这个重要文件了,这个文件是我主动放进去的,必需的)

安装包连接   https://pan.baidu.com/s/1skB28aT

B、在window系统中配置HADOOP_HOME指向你解压的安装包目录

C、在windows系统的path变量中加入HADOOP_HOMEbin目录

D、重启电脑


第二步:在idea中配置访问用户


在driver中加入代码,冲hdfs中读取数据,指定yarn,集群在本地运行

Configuration conf = new Configuration();
conf.set("fs.defaultFS", "hdfs://hadoop01:9000");
conf.set("yarn.resourcemanager.hostname", "hadoop01");

第三步启动项目会报错如下:

Exception in thread "main" java.lang.UnsatisfiedLinkError: org.apache.hadoop.io.nativeio.NativeIO$Windows.access0(Ljava/lang/String;I)Z
at org.apache.hadoop.io.nativeio.NativeIO$Windows.access0(Native Method)
at org.apache.hadoop.io.nativeio.NativeIO$Windows.access(NativeIO.java:557)
at org.apache.hadoop.fs.FileUtil.canRead(FileUtil.java:977)
at org.apache.hadoop.util.DiskChecker.checkAccessByFileMethods(DiskChecker.java:187)
at org.apache.hadoop.util.DiskChecker.checkDirAccess(DiskChecker.java:174)
at org.apache.hadoop.util.DiskChecker.checkDir(DiskChecker.java:108)

导致报错的原因是:

是你的hadoop.dll 文件和你当前的hadoop版本不匹配,
第一步没有处理好,解决这个问题的办法:一:重新将hadoop针对window进行编译。
或者采用方法二:
修改源码,下载相应版本的源码解压,找到NativeIO.java文件。将它加入到工程中去(注意在已有项目下建个相同的包,项目会自动舍弃.class文件引用java文件),如下图,并修改NativeIO.java。return access0(....);修改为return true;


 
 



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值