一个eureka注册中心服务,之前都正常运行的,昨天通过java -jar 方式运行时报错
java.lang.TypeNotPresentException: Type javax.xml.bind.JAXBContext not present
java.lang.TypeNotPresentException: Type javax.xml.bind.JAXBContext not present
at java.base/sun.reflect.generics.factory.CoreReflectionFactory.makeNamedType(CoreReflectionFactory.java:117) ~[na:na]
at java.base/sun.reflect.generics.visitor.Reifier.visitClassTypeSignature(Reifier.java:125) ~[na:na]
at java.base/sun.reflect.generics.tree.ClassTypeSignature.accept(ClassTypeSignature.java:49) ~[na:na]
at java.base/sun.reflect.generics.visitor.Reifier.reifyTypeArguments(Reifier.java:68) ~[na:na]
at java.base/sun.reflect.generics.visitor.Reifier.visitClassTypeSignature(Reifier.java:138) ~[na:na]
at java.base/sun.reflect.generics.tree.ClassTypeSignature.accept(ClassTypeSignature.java:49) ~[na:na]
at java.base/sun.reflect.generics.repository.ClassRepository.computeSuperInterfaces(ClassRepository.java:117) ~[na:na]
at java.base/sun.reflect.generics.repository.ClassRepository.getSuperInterfaces(ClassRepository.java:95) ~[na:na]
at java.base/java.lang.Class.getGenericInterfaces(Class.java:1137) ~[na:na]
再回到eclipse中运行原本的工程时,可以正常运行,不会报错。
排查搜了一下,发现是JAXB-API引起的,这个内容是jdk9引起的,而eclipse中配置的jdk一直是jdk8。上个月有在电脑上安装了新的jdk11,但是并没有在环境变量中配置新的jdk路径
在窗口验证jdk版本,果然是jdk11
环境变量配置如下
这里可以看到JAVA_HOME配置的是jdk8的目录,点开查看下path的各项内容如下
这里%JAVA_HOME%\bin 上面还有几条与java相关的配置项,点第一条 C:\Program Files\Common Files\Oracle\Java\javapath 进去看一下
可以查看到javapath里面有一个java.exe可执行命令,且其版本号为11.0.10.0,高于我们原本设置的jdk8。
其它两条的内容类似,就不一一查看了。
要解决这个问题,可以调整下path中跟jdk相关的内容
- 调整%JAVA_HOME%\bin 到最前面
- 删除除%JAVA_HOME%\bin之外的jdk相关配置
我们试一下第一种方法,调整%JAVA_HOME%\bin到最前面
保存测试,这里要重启一点电脑,否则还会查看到jdk11,重启后,可以看到环境变量中取到的jdk版本为jdk8
再次启动文初的服务,可以正常启动。