博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java.lang.IncompatibleClassChangeError
阅读量:5883 次
发布时间:2019-06-19

本文共 2708 字,大约阅读时间需要 9 分钟。

hot3.png

不兼容的类变化错误。当正在执行的方法所依赖的类定义发生了不兼容的改变时,抛出该异常。一般在修改了应用中的某些类的声明定义而没有对整个应用重新编译而直接运行的情况下,容易引发该错误。

【报错信息】

[ERROR] Terminal initialization failed; falling back to unsupported

java.lang.IncompatibleClassChangeError: Found class jline.Terminal, but interface was expected

    at jline.TerminalFactory.create(TerminalFactory.java:101)    at jline.TerminalFactory.get(TerminalFactory.java:158)    at jline.console.ConsoleReader.
(ConsoleReader.java:229)    at jline.console.ConsoleReader.
(ConsoleReader.java:221)    at jline.console.ConsoleReader.
(ConsoleReader.java:209)    at org.apache.hadoop.hive.cli.CliDriver.setupConsoleReader(CliDriver.java:787)    at org.apache.hadoop.hive.cli.CliDriver.executeDriver(CliDriver.java:721)    at org.apache.hadoop.hive.cli.CliDriver.run(CliDriver.java:681)    at org.apache.hadoop.hive.cli.CliDriver.main(CliDriver.java:621)    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)    at java.lang.reflect.Method.invoke(Method.java:606)    at org.apache.hadoop.util.RunJar.run(RunJar.java:221)    at org.apache.hadoop.util.RunJar.main(RunJar.java:136)

Exception in thread “main” java.lang.IncompatibleClassChangeError: Found class jline.Terminal, but interface was expected

    at jline.console.ConsoleReader.
(ConsoleReader.java:230)    at jline.console.ConsoleReader.
(ConsoleReader.java:221)    at jline.console.ConsoleReader.
(ConsoleReader.java:209)    at org.apache.hadoop.hive.cli.CliDriver.setupConsoleReader(CliDriver.java:787)    at org.apache.hadoop.hive.cli.CliDriver.executeDriver(CliDriver.java:721)    at org.apache.hadoop.hive.cli.CliDriver.run(CliDriver.java:681)    at org.apache.hadoop.hive.cli.CliDriver.main(CliDriver.java:621)    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)    at java.lang.reflect.Method.invoke(Method.java:606)    at org.apache.hadoop.util.RunJar.run(RunJar.java:221)    at org.apache.hadoop.util.RunJar.main(RunJar.java:136)

stack@op4:~$

【解决办法】

原因:YARN中的jline版本过低。

${hive_home}/lib目录的jlinecopy${hadoop_home}/share/hadoop/yarn/lib目录下,启动hive。

解决:将hive-lib中的jline替换到yarn-lib目录中:

cp $ HIVE_HOME/lib/jline-2.12.jar $HADOOP_HOME/share/hadoop/yarn/lib/

rm -f $HADOOP_HOME/share/hadoop/yarn/lib/jline-0.9.94.jar

问题解决

 

转载于:https://my.oschina.net/wangshao/blog/643759

你可能感兴趣的文章
好作品地址
查看>>
[翻译]Protocol Buffer 基础: C++
查看>>
runloop与线程的关系
查看>>
[Bzoj2246]迷宫探险(概率+DP)
查看>>
详解消息队列的设计与使用
查看>>
使用Sqoop从mysql向hdfs或者hive导入数据时出现的一些错误
查看>>
控制子窗口的高度
查看>>
处理 Oracle SQL in 超过1000 的解决方案
查看>>
Alpha线性混合实现半透明效果
查看>>
chkconfig 系统服务管理
查看>>
ORACLE---Unit04: SQL(高级查询)
查看>>
贪食蛇
查看>>
201521123009 《Java程序设计》第11周学习总结
查看>>
Python3之多线程学习
查看>>
MVC和MTV结构分析
查看>>
(转)微信网页扫码登录的实现
查看>>
mariadb启动报错:[ERROR] Can't start server : Bind on unix socket: Permission denied
查看>>
nginx的信号量
查看>>
云im php,网易云IM
查看>>
河南农业大学c语言平时作业答案,河南农业大学2004-2005学年第二学期《C语言程序设计》期末考试试卷(2份,有答案)...
查看>>