首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >AppClassLoader :虽然使用JDK8,但不能将JDK8转换为JDK8

AppClassLoader :虽然使用JDK8,但不能将JDK8转换为JDK8
EN

Stack Overflow用户
提问于 2017-12-20 01:40:16
回答 3查看 11K关注 0票数 10

在安装jdk9之后,我看到了以下问题:

代码语言:javascript
复制
$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.<init>(SessionState.java:394)
    at org.apache.hadoop.hive.ql.session.SessionState.<init>(SessionState.java:370)
    at org.apache.hadoop.hive.cli.CliSessionState.<init>(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

代码语言:javascript
复制
$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

代码语言:javascript
复制
vi $(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

代码语言:javascript
复制
$/usr/libexec/java_home --version 1.8
/Library/Java/JavaVirtualMachines/jdk1.8.0_144.jdk/Contents/Home

我还应该在这里调查什么?

我是hive 2.3.1 on macos

代码语言:javascript
复制
 $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
EN

回答 3

Stack Overflow用户

发布于 2020-01-17 20:48:43

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

票数 3
EN

Stack Overflow用户

发布于 2018-01-03 06:39:27

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

看蜂巢,它用

代码语言:javascript
复制
JAVA_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" "$@".
票数 1
EN

Stack Overflow用户

发布于 2019-09-13 21:00:51

在设置hive时,我也遇到了同样的错误,最初我认为这可能是因为不同的java版本。

但是在检查java版本时,它是JDK1.8。

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

我删除了jdk 10,最后它成功了。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47897645

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档