近期因为项目log4j升级由2.17.1升级为log4j 2.18.0出现了一个非常奇怪的问题,就是测试环境不会报错而本地环境报错 NoClassDefFoundError:org.osgi.framework.BundleContext,确实我们也没有使用或者引入BundleContext,最后分析原来是测试环境和本地的JDK版本不一样,本地使用IBM1.8,测试使用的是openjdk1.8。IBM1.8在加载类的时候在使用到OsgiServiceLocator时候就会主动加载BundleContext。但是openjdk1.8不会。结论是在jar包文件中的class文件即使import 不存在的类也不一定报错,除非加载这个不存在类,同时是否加载不存在的类不同jdk处理不一样。
关于Apache Log4j 2.18.0使用OSGI后报错研究
于 2022-08-20 09:29:11 首次发布