今天在研究Elasticsearch 关于SQL 查询功能,出现了一个问题,不能使用命令行客户端执行SQL操作,异常信息如下:
Exception in thread "main" java.io.IOError: java.lang.UnsupportedOperationException
at org.jline.utils.Curses.tputs(Curses.java:62)
at org.jline.utils.Curses.tputs(Curses.java:45)
at org.jline.keymap.KeyMap.key(KeyMap.java:243)
at org.jline.reader.impl.LineReaderImpl.key(LineReaderImpl.java:5666)
at java.util.stream.ReferencePipeline$3$1.accept(ReferencePipeline.java:193)
at java.util.stream.ReferencePipeline$2$1.accept(ReferencePipeline.java:175)
at java.util.Spliterators$ArraySpliterator.forEachRemaining(Spliterators.java:948)
at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:481)
at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:471)
at java.util.stream.ForEachOps$ForEachOp.evaluateSequential(ForEachOps.java:151)
at java.util.stream.ForEachOps$ForEachOp$OfRef.evaluateSequential(ForEachOps.java:174)
at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
at java.util.stream.ReferencePipeline.forEach(ReferencePipeline.java:418)
at org.jline.reader.impl.LineReaderImpl.bindKeys(LineReaderImpl.java:5674)
at org.jline.reader.impl.LineReaderImpl.emacs(LineReaderImpl.java:5387)
at org.jline.reader.impl.LineReaderImpl.defaultKeyMaps(LineReaderImpl.java:5363)
at org.jline.reader.impl.LineReaderImpl.<init>(LineReaderImpl.java:266)
at org.jline.reader.LineReaderBuilder.build(LineReaderBuilder.java:115)
at org.elasticsearch.xpack.sql.cli.JLineTerminal.<init>(JLineTerminal.java:47)
at org.elasticsearch.xpack.sql.cli.Cli.main(Cli.java:58)
Caused by: java.lang.UnsupportedOperationException
at org.jline.utils.Curses.doTputs(Curses.java:78)
at org.jline.utils.Curses.tputs(Curses.java:60)
... 19 more
从异常信息中,可以是JLineTerminal 出现了问题,J 不知道是什么意思,LineTerminal 可以看出是命令行终端,大致可以怀疑是OS的问题。这种问题还是问度娘吧
这个文章的意思是这个问题是由于OS中的$TERM = linux 导致的,具体办法,设置变量$TERM=xterm 如下:
实际测试结果,可以解决该问题: