报错:Caused by: java.lang.RuntimeException: Error while running command to get file permissions : java.io.IOException: (null) entry in command string: null ls -F D:\tmp\hive
或者报错:The root scratch dir: /tmp/hive on HDFS should be writable. Current permissions are: --------

报错原因
这个问题主要是因为 Spark初始化Hive上下文所需的winutils.exe丢失文件引起的,而该 文件又依赖于 Hadoop,后者需要Windows上有hadoop才可以;

winutils.exe下载链接:
https://github.com/steveloughran/winutils/raw/master/hadoop-2.6.0/bin/winutils.exe

Hadoop下载链接:
http://spark.apache.org/downloads.html 选择spark版本,这里我选的是2.4.4
解决方案:

winutils.exe和hadoop都下载完后,将winutils.exe放入下载的hadoop\bin目录下

Hadoop存储位置需和你 报错信息中的 \tmp\hive的位置要一致

上述报错中,我报错位置是 null ls -F D:\tmp\hive 所以我将hadoop放到了D:\下

(注意:如果是第二种报错随便找个地方放着就行)

然后找根目录或者放hadoop的目录看看有没有tmp/hive这个目录有就删除

上述步骤都完成后,在我的电脑属性中配置环境变量HADOOP_HOME指定到我们haodoop的根目录下
然后在Path下配置%HADOOP_HOME%\bin

环境变量配置完后,win+r打开cmd窗口

执行spark-shell命令,打开spark交互窗口

随意执行一句sqrksql(hsql)语句,这里我执行的是 spark.sql(“show databases”).show

执行完后,去我们存放hadoop的根目录下查看是否,生成目录tmp

(注意:如果是第二种报错指不定在哪个盘符的根目录下自己找)

当成功后,退出spark 切换盘符到存放hadoop的根目录下,重新打开cmd

输入%HADOOP_HOME%\bin\winuitls.exe chmod 777 \tmp\hive 修改文件夹权限

此时,如果你的ideal正在运行,请关闭它(最好这样做,不关闭有可能前面步骤你都做对了,但是还是会报之前的错)

重启ideal 运行你的程序,一般就没问题了

重点
如果你是win10上述问题解决了但是只执行show tables 、show databases类似的语句不能执行select语句,或者执行了报错如下

java.lang.UnsatisfiedLinkError: org.apache.hadoop.util.NativeCrc32.nativeComput

修改方案:在程序运行前,添加`-Djava.library.path=$HADOOP_HOME/lib/native`参数,如果是idea,是下面这个位置

 

 

 

IDEA中sparksession连接hive的种种问题

参考链接:https://blog.csdn.net/Coder__CS/article/details/79128222

参考链接:https://blog.csdn.net/zgjdzwhy/article/details/71056801

 

 

相关文章: