java.io.IOException: Could not locate executable null\bin\winutils.exe in the Hadoop binaries 快速解决

报错信息:

java.io.IOException: Could not locate executable null\bin\winutils.exe in the Hadoop binaries.
	at org.apache.hadoop.util.Shell.getQualifiedBinPath(Shell.java:382)
	at org.apache.hadoop.util.Shell.getWinUtilsPath(Shell.java:397)
	at org.apache.hadoop.util.Shell.<clinit>(Shell.java:390)
	at org.apache.hadoop.util.StringUtils.<clinit>(StringUtils.java:80)
	at org.apache.hadoop.security.SecurityUtil.getAuthenticationMethod(SecurityUtil.java:611)
	at org.apache.hadoop.security.UserGroupInformation.initialize(UserGroupInformation.java:273)
	at org.apache.hadoop.security.UserGroupInformation.ensureInitialized(UserGroupInformation.java:261)
	at org.apache.hadoop.security.UserGroupInformation.loginUserFromSubject(UserGroupInformation.java:806)
	at org.apache.hadoop.security.UserGroupInformation.getLoginUser(UserGroupInformation.java:776)
	at org.apache.hadoop.security.UserGroupInformation.getCurrentUser(UserGroupInformation.java:649)
	at org.apache.spark.util.Utils$.$anonfun$getCurrentUserName$1(Utils.scala:2412)
	at scala.Option.getOrElse(Option.scala:189)
	at org.apache.spark.util.Utils$.getCurrentUserName(Utils.scala:2412)
	at org.apache.spark.SparkContext.<init>(SparkContext.scala:308)
	at org.apache.spark.SparkContext$.getOrCreate(SparkContext.scala:2574)
	at org.apache.spark.sql.SparkSession$Builder.$anonfun$getOrCreate$2(SparkSession.scala:934)
	at scala.Option.getOrElse(Option.scala:189)
	at org.apache.spark.sql.SparkSession$Builder.getOrCreate(SparkSession.scala:928)
	at cn.itcast.sql.Demo01$.main(Demo01.scala:14)
	at cn.itcast.sql.Demo01.main(Demo01.scala)

**报错原因:**spark运行缺少本地Hadoop环境,您缺少winutils.exe,一个hadoop二进制文件。

首先下载winutils.exe文件,链接:https://pan.baidu.com/s/1fPVtQxzHv5oRW14Far3y3Q
提取码:CCNB

解决办法一:
快速解决:

//在程序中添加如下代码,快速解决当前类问题,彻底解决解决办法二操作
System.setProperty("hadoop.home.dir","我提供的文件夹的目录")
//例如
System.setProperty("hadoop.home.dir","D:\\OPT\\IDEA\\IDEA-plugins\\Hadoop")

然后重新运行程序,无效重启IDEA再尝试下,或尝试下解决办法二

解决办法二:
添加环境变量:
打开环境变量:
1.在用户变量创建HADOOP_HOME,变量值选择Hadoop文件夹存放位置
2.在系统变量中找到Path,没有则创建,变量值中添加引号中内容,"%HADOOP_HOME%\bin ;" 如果要放到开头,注意最后的";"号,不要丢了
3.点击确定保存,重启计算机,不想现在重启计算机,可以使用解决办法一,等下次重启则此配置生效
在这里插入图片描述

本文原创,如需转发引用,请注明出处

有用的话点个赞呦

链接失效可评论/私信

  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值