关于java:Hive:尽管使用JDK8,但AppClassLoader无法转换为URLClassLoader

您所在的位置:网站首页 怎么把c盘变大win10 关于java:Hive:尽管使用JDK8,但AppClassLoader无法转换为URLClassLoader

关于java:Hive:尽管使用JDK8,但AppClassLoader无法转换为URLClassLoader

#关于java:Hive:尽管使用JDK8,但AppClassLoader无法转换为URLClassLoader | 来源: 网络整理| 查看: 265

安装jdk9后,我一直看到此问题:

12345678910111213141516171819$hive Java HotSpot(TM) 64-Bit Server VM warning: Ignoring option MaxPermSize; support was removed in 8.0 SLF4J: Class path contains multiple SLF4J bindings. SLF4J: Found binding in [jar:file:/usr/local/Cellar/hive/2.3.1/libexec/lib/log4j-slf4j-impl-2.6.2.jar!/org/slf4j/impl/StaticLoggerBinder.class] SLF4J: Found binding in [jar:file:/usr/local/Cellar/hadoop/2.8.1/libexec/share/hadoop/common/lib/slf4j-log4j12-1.7.10.jar!/org/slf4j/impl/StaticLoggerBinder.class] SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation. SLF4J: Actual binding is of type [org.apache.logging.slf4j.Log4jLoggerFactory] Exception in thread"main" java.lang.ClassCastException: java.base/jdk.internal.loader.ClassLoaders$AppClassLoader cannot be cast to java.base/java.net.URLClassLoader     at org.apache.hadoop.hive.ql.session.SessionState.(SessionState.java:394)     at org.apache.hadoop.hive.ql.session.SessionState.(SessionState.java:370)     at org.apache.hadoop.hive.cli.CliSessionState.(CliSessionState.java:60)     at org.apache.hadoop.hive.cli.CliDriver.run(CliDriver.java:708)     at org.apache.hadoop.hive.cli.CliDriver.main(CliDriver.java:686)     at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)     at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)     at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)     at java.base/java.lang.reflect.Method.invoke(Method.java:564)     at org.apache.hadoop.util.RunJar.run(RunJar.java:234)     at org.apache.hadoop.util.RunJar.main(RunJar.java:148)

但我有

更新了$PATH以指向java8

1234$java -version java version"1.8.0_144" Java(TM) SE Runtime Environment (build 1.8.0_144-b01) Java HotSpot(TM) 64-Bit Server VM (build 25.144-b01, mixed mode)

更新了hive可执行文件以指定java8

1234vi $(which hive) #!/bin/bash JAVA_HOME="$(/usr/libexec/java_home --version 1.8)" HIVE_HOME="/usr/local/Cellar/hive/2.3.1/libexec" exec"/usr/local/Cellar/hive/2.3.1/libexec/bin/hive""$@"

验证更新的Java版本确实指向jdk8

12$/usr/libexec/java_home --version 1.8 /Library/Java/JavaVirtualMachines/jdk1.8.0_144.jdk/Contents/Home

我还要在这里寻找什么?

这是macos上的hive 2.3.1

12345 $hive --version Hive 2.3.1 Git git://jcamachorodriguez-rMBP.local/Users/jcamachorodriguez/src/workspaces/hive/HIVE-apache/hive -r 7590572d9265e15286628013268b2ce785c6aa08 Compiled by jcamachorodriguez on Thu Oct 19 18:37:58 PDT 2017 From source with checksum 03c91029a6103bd91f25a6ff8a01fbcd 相关讨论 是否有较新版本的Hive? 自JDK 8起,MaxPermSize已过时。ClassCastException是Hive,它假设系统类加载器是URLClassLoader(在JDK 9中已更改,请参见此处的发行说明:oracle.com/technetwork/java/javase/)。 如OP中所述,我已更新为指向JDK8,以避免您提到的JDK9问题。

安装jdk8并在hadoop-env.sh中相应地更改路径,这对我有用。

我有同样的问题,我只删除了JDK 9而不是更改环境,问题就解决了。

看到蜂巢,它使用

123JAVA_HOME="$(/usr/libexec/java_home --version 1.7+)" HIVE_HOME="/usr/local/Cellar/hive/2.3.1/libexec" exec"/usr/local/Cellar/hive/2.3.1/libexec/bin/hive""$@". 相关讨论 我需要JDK9在系统上可用。 也许这种方法可以解决,但希望有一个基于配置的解决方案。

设置配置单元时,我遇到了相同的错误,最初我认为可能是由于Java版本不同所致。

但是在检查Java版本时,它是jdk 1.8。

最后在检查jdk安装目录(/ Library / Java / JavaVirtualMachine)时,我发现同时存在jdk 1.8和jdk 10

我删除了jdk 10,终于奏效了。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3