背景:同事把kettle工具刚刚倒过来,打开spoon.bat报错,显示Error: Could not create the Java Virtual Machine.
发现问题后运行SpoonDebug.bat,寻找具体问题,输出结果:
Error: Could not create the Java Virtual Machine.
Error: A fatal exception has occurred. Program will exit.
Invalid maximum heap size: -Xmx4096m
The specified size exceeds the maximum representable size.
结果中发现JVM的内存空间设置问题,之前的-Xms1024m;-Xmx4096m;-XX:MaxPermSize=6144m,后查阅相关资料,修改编辑打开spoon.bat,找到jvm设置空间的地方将其调整为if "%PENTAHO_DI_JAVA_OPTIONS%"=="" set PENTAHO_DI_JAVA_OPTIONS="-Xms512m" "-Xmx512m" "-XX:MaxPermSize=256m"。之后运行内存问题得以解决,却出现新问题,直接上debug输出结果:
java.lang.UnsupportedClassVersionError: org/pentaho/commons/launcher/Launcher : Unsupported major.minor version 52.0
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:800)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:449)
at java.net.URLClassLoader.access$100(URLClassLoader.java:71)
at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:482)
Exception in thread "main"
此问题原因在于java的jdk版本过低导致,后于官网https://www.oracle.com/technetwork/java/javase/downloads/index.html下载最新jdk安装后,问题得以解决,spoon正常打开使用。
望此解决方案可以为同样困惑的你提供帮助!