IDEA写hiveContext报错HiveSessionState

在使用IDEA开发过程中,遇到运行HiveContext时抛出IllegalArgumentException,错误涉及SparkSession的初始化失败。异常堆栈显示问题出在创建HiveSessionState时,具体为NullPointer异常。问题可能源于Hadoop配置、Hive元数据目录权限或者环境变量设置不正确。解决方法包括检查HDFS配置、确保Hive元数据目录存在且可写,以及确认相关环境变量已设置。请尝试排查这些方面并修复问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

错误:
Exception in thread “main” java.lang.IllegalArgumentException: Error while instantiating ‘org.apache.spark.sql.hive.HiveSessionState’:
at org.apache.spark.sql.SparkSession.org.org.orgapachesparksparksparksqlSparkSessionSparkSessionSparkSessionreflect(SparkSession.scala:981)atorg.apache.spark.sql.SparkSession.sessionStatereflect(SparkSession.scala:981) at org.apache.spark.sql.SparkSession.sessionStatereflect(SparkSession.scala:981)atorg.apache.spark.sql.SparkSession.sessionStatelzycompute(SparkSession.scala:110)
at org.apache.spark.sql.SparkSession.sessionState(SparkSession.scala:109)
at org.apache.spark.sql.SparkSession.table(SparkSession.scala:574)
at org.apache.spark.sql.SQLContext.table(SQLContext.scala:708)
at com.imooc.spark.HiveContextApp.main(HiveContextApp.scala:18)atcom.imooc.spark.HiveContextApp.main(HiveContextApp.scala)Causedby:java.lang.reflect.InvocationTargetExceptionatsun.reflect.NativeConstructorAccessorImpl.newInstance0(NativeMethod)atsun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)atsun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)atjava.lang.reflect.Constructor.newInstance(Constructor.java:423)atorg.apache.spark.sql.SparkSession.main(HiveContextApp.scala:18) at com.imooc.spark.HiveContextApp.main(HiveContextApp.scala) Caused by: java.lang.reflect.InvocationTargetException at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) at java.lang.reflect.Constructor.newInstance(Constructor.java:423) at org.apache.spark.sql.SparkSession.main(HiveContextApp.scala:18)atcom.imooc.spark.HiveContextApp.main(HiveContextApp.scala)Causedby:java.lang.reflect.InvocationTargetExceptionatsun.reflect.NativeConstructorAccessorImpl.newInstance0(NativeMethod)atsun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)atsun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)atjava.lang.reflect.Constructor.newInstance(Constructor.java:423)atorg.apache.spark.sql.SparkSession.orgapacheapacheapachesparksqlsqlsqlSparkSessionKaTeX parse error: Can't use function '$' in math mode at position 212: …nal.SharedState$̲.org$apache$spa…reflect(SharedState.scala:169)
at org.apache.spark.sql.internal.SharedState.(SharedState.scala:86)
at org.apache.spark.sql.SparkSessionKaTeX parse error: Can't use function '$' in math mode at position 8: anonfun$̲sharedState$1.a…anonfun$sharedState1.apply(SparkSession.scala:101)atscala.Option.getOrElse(Option.scala:120)atorg.apache.spark.sql.SparkSession.sharedState1.apply(SparkSession.scala:101) at scala.Option.getOrElse(Option.scala:120) at org.apache.spark.sql.SparkSession.sharedState1.apply(SparkSession.scala:101)atscala.Option.getOrElse(Option.scala:120)atorg.apache.spark.sql.SparkSession.sharedStatelzycompute(SparkSession.scala:101)
at org.apache.spark.sql.SparkSession.sharedState(SparkSession.scala:100)
at org.apache.spark.sql.internal.SessionState.(SessionState.scala:157)
at org.apache.spark.sql.hive.HiveSessionState.(HiveSessionState.scala:32)
… 11 more
Caused by: java.lang.reflect.InvocationTargetException
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
at org.apache.spark.sql.internal.SharedState.org.org.orgapachesparksparksparksqlinternalinternalinternalSharedState$reflect(SharedState.scala:166)...19moreCausedby:java.lang.reflect.InvocationTargetExceptionatsun.reflect.NativeConstructorAccessorImpl.newInstance0(NativeMethod)atsun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)atsun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)atjava.lang.reflect.Constructor.newInstance(Constructor.java:423)atorg.apache.spark.sql.hive.client.IsolatedClientLoader.createClient(IsolatedClientLoader.scala:264)atorg.apache.spark.sql.hive.HiveUtilsreflect(SharedState.scala:166) ... 19 more Caused by: java.lang.reflect.InvocationTargetException at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) at java.lang.reflect.Constructor.newInstance(Constructor.java:423) at org.apache.spark.sql.hive.client.IsolatedClientLoader.createClient(IsolatedClientLoader.scala:264) at org.apache.spark.sql.hive.HiveUtilsreflect(SharedState.scala:166)...19moreCausedby:java.lang.reflect.InvocationTargetExceptionatsun.reflect.NativeConstructorAccessorImpl.newInstance0(NativeMethod)atsun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)atsun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)atjava.lang.reflect.Constructor.newInstance(Constructor.java:423)atorg.apache.spark.sql.hive.client.IsolatedClientLoader.createClient(IsolatedClientLoader.scala:264)atorg.apache.spark.sql.hive.HiveUtils.newClientForMetadata(HiveUtils.scala:366)
at org.apache.spark.sql.hive.HiveUtils.newClientForMetadata(HiveUtils.scala:270)atorg.apache.spark.sql.hive.HiveExternalCatalog.&lt;init&gt;(HiveExternalCatalog.scala:65)...24moreCausedby:java.lang.RuntimeException:java.lang.NullPointerExceptionatorg.apache.hadoop.hive.ql.session.SessionState.start(SessionState.java:522)atorg.apache.spark.sql.hive.client.HiveClientImpl.&lt;init&gt;(HiveClientImpl.scala:192)...32moreCausedby:java.lang.NullPointerExceptionatjava.lang.ProcessBuilder.start(ProcessBuilder.java:1012)atorg.apache.hadoop.util.Shell.runCommand(Shell.java:404)atorg.apache.hadoop.util.Shell.run(Shell.java:379)atorg.apache.hadoop.util.Shell.newClientForMetadata(HiveUtils.scala:270) at org.apache.spark.sql.hive.HiveExternalCatalog.&lt;init&gt;(HiveExternalCatalog.scala:65) ... 24 more Caused by: java.lang.RuntimeException: java.lang.NullPointerException at org.apache.hadoop.hive.ql.session.SessionState.start(SessionState.java:522) at org.apache.spark.sql.hive.client.HiveClientImpl.&lt;init&gt;(HiveClientImpl.scala:192) ... 32 more Caused by: java.lang.NullPointerException at java.lang.ProcessBuilder.start(ProcessBuilder.java:1012) at org.apache.hadoop.util.Shell.runCommand(Shell.java:404) at org.apache.hadoop.util.Shell.run(Shell.java:379) at org.apache.hadoop.util.Shell.newClientForMetadata(HiveUtils.scala:270)atorg.apache.spark.sql.hive.HiveExternalCatalog.<init>(HiveExternalCatalog.scala:65)...24moreCausedby:java.lang.RuntimeException:java.lang.NullPointerExceptionatorg.apache.hadoop.hive.ql.session.SessionState.start(SessionState.java:522)atorg.apache.spark.sql.hive.client.HiveClientImpl.<init>(HiveClientImpl.scala:192)...32moreCausedby:java.lang.NullPointerExceptionatjava.lang.ProcessBuilder.start(ProcessBuilder.java:1012)atorg.apache.hadoop.util.Shell.runCommand(Shell.java:404)atorg.apache.hadoop.util.Shell.run(Shell.java:379)atorg.apache.hadoop.util.ShellShellCommandExecutor.execute(Shell.java:589)
at org.apache.hadoop.util.Shell.execCommand(Shell.java:678)
at org.apache.hadoop.util.Shell.execCommand(Shell.java:661)
at org.apache.hadoop.fs.FileUtil.execCommand(FileUtil.java:1097)
at org.apache.hadoop.fs.RawLocalFileSystemRawLocalFileStatus.loadPermissionInfo(RawLocalFileSystem.java:567)atorg.apache.hadoop.fs.RawLocalFileSystemRawLocalFileStatus.loadPermissionInfo(RawLocalFileSystem.java:567) at org.apache.hadoop.fs.RawLocalFileSystemRawLocalFileStatus.loadPermissionInfo(RawLocalFileSystem.java:567)atorg.apache.hadoop.fs.RawLocalFileSystemRawLocalFileStatus.getPermission(RawLocalFileSystem.java:542)
at org.apache.hadoop.hive.ql.session.SessionState.createRootHDFSDir(SessionState.java:599)
at org.apache.hadoop.hive.ql.session.SessionState.createSessionDirs(SessionState.java:554)
at org.apache.hadoop.hive.ql.session.SessionState.start(SessionState.java:508)
… 33 more

求大佬解决!!!

### Intellij IDEA Debug 运行报错解决方案 当在IntelliJ IDEA中进行远程调试时,如果遇到`java.net.ConnectException "Connection refused: connect"`错误[^1],这通常意味着客户端无法连接到指定的服务器端口。可能的原因包括防火墙阻止、目标机器上的服务未启动或配置不正确。 对于IDEA中代码能够正常运行但在Debug模式下报错的情况,一种常见的解决方法涉及调整设置而非更改文件路径。具体来说,在菜单栏选择 **File** -> **Settings** (Windows/Linux) 或者 **IntelliJ IDEA** -> **Preferences** (macOS),导航至 **Build, Execution, Deployment** 下的 **Debugger** 设置页面。在这里找到并取消选中 **Async Stack Traces** 选项中的复选框,保存更改后再次尝试调试操作[^2]。 另外,若项目能通过常规方式启动而仅在启用调试功能时报错,则可能是由于某些特定于调试环境的因素引起的。此时应仔细检查项目的依赖项以及任何与调试有关的特殊配置,确保它们之间不存在冲突[^3]。 最后,如果是Tomcat容器内部发生的监听器启动失败(`Error listenerStart`)问题,那么应当关注具体的异常堆栈信息来定位根本原因。例如,由Spring框架引发的 `ConflictingBeanDefinitionException` 表明存在同名的不同类定义之间的命名空间冲突;针对这种情况,修正相应的Java源码以消除名称重复即可解决问题[^4]。 ```xml <!-- 修改前 --> <bean id="newsManagerController" class="com.qf.official.controller.NewsManagerController"/> ... <bean id="newsManagerController" class="com.qf.bookbar.news.controller.NewsManagerController"/> <!-- 修改后 --> <bean id="uniqueNewsManagerCtrlOfficial" class="com.qf.official.controller.NewsManagerController"/> ... <bean id="uniqueNewsManagerCtrlBookBar" class="com.qf.bookbar.news.controller.NewsManagerController"/> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值