最近用到karaf,而karaf的控制台使用了jline处理控制台输入。
在Eclipse下运行时,控制台无法接受输入,输入命令、回车,系统没反应。
原因是在通过JNI调用本地WindowsAPI时,本地的private static final native int ReadConsoleInputW()方法返回了非预期的值。导致控制台读取部分实际上处于死循环状态。
解决方法:设置系统属性jline.WindowsTerminal.directConsole为false。
(绕过本地库Windows API调用,直接使用Java IO流读取输入)
主要参考了:http://whitesock.iteye.com/blog/692816
打开jline的日志:设置系统属性jline.internal.Log.debug为true
另外,要调试jline的话,几个依赖库:
<dependency>
<groupId>org.fusesource.hawtjni</groupId>
<artifactId>hawtjni-runtime</artifactId>
<version>1.11</version>
</dependency>
<dependency>
<groupId>org.fusesource.jansi</groupId>
<artifactId>jansi-native</artifactId>
<version>1.5</version>
</dependency>
<dependency>
<groupId>jline</groupId>
<artifactId>jline</artifactId>
<version>2.13</version>
</dependency>
调试代码:
public static void main(String[] args) throws Exception {
System.setProperty("jline.internal.Log.debug", "true");
//System.setProperty("jline.WindowsTerminal.directConsole", "false");
ConsoleReader console = new ConsoleReader();
String line = console.readLine();
System.out.println("----" + line);
}
对于karaf shell中包含 more输出方式的命令,more的执行效果仍然有问题。
比如,对于help命令。(按每一个字母都分别输出了---more----)
可以修改etc\shell.init.script文件,修改其:
help = { *:help $args | more } ; 改为:
help = { *:help $args } ;