2017-12-20 7 views
2

사용하지만, URLClassLoader를 캐스팅 할 수 없습니다하이브 : AppClassLoader 나는이 문제를보고 한 <code>jdk9</code>를 설치 한 후 JDK8

$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) 

을하지만 java8를 가리 키도록 $PATH 업데이트

$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

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" "[email protected]" 

업데이트 된 자바 버전은 여기에보고해야한다 또 어떤

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

jdk8 가리 않는 검증?

이 난 그냥 JDK (9) 대신 변화의 환경을 제거하고, 문제 해결, 내가 같은 문제가 macos

$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 
+1

은 하이브의 새 버전이 사용? MaxPermSize는 JDK 8부터 사용되지 않습니다. ClassCastException은 시스템 클래스 로더가 URLClassLoader라는 가정하에 하이브입니다 (JDK 9에서 변경됨, 릴리스 노트 참조). http://www.oracle.com/technetwork/java/javase /9-relnote-issues-3704069.html#JDK-8142968). –

+0

OP에서 언급했듯이'JDK8'을 피하기 위해'JDK8 '을 가리 키도록 업데이트했습니다. – javadba

답변

0

hive 2.3.1입니다.

참조 하이브, 그것은

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" "[email protected]". 
+0

시스템에서 JDK9를 사용할 수 있어야합니다. 어쩌면이 접근법은 해결 방법으로 작동 할 수 있지만 구성 기반 솔루션이 있기를 바랍니다. – javadba

관련 문제