我们有一个生产 Java 1.6 / Tomcat 7 / Spring 4 应用程序。
我们正在将其移至 Openjdk 11。这意味着 Spring 5,我认为它可能还包括 Tomcat 9,因为我们正在更新其他所有内容。
问题是不言自明的声音:
错误 org.springframework.web.context.ContextLoader - 上下文初始化失败 org.springframework.beans.factory.UnsatisfiedDependencyException:创建名称为“rootContextConfig”的 bean 时出错:通过字段“entityManagerFactory”表示不满足的依赖关系;嵌套异常是 org.springframework.beans.factory.BeanCreationException:创建 com.xxxxx.config.RootContextConfig 中定义的名称为“entityManagerFactory”的 bean 时出错:调用 init 方法失败;嵌套异常是 java.lang.IllegalStateException:必须从 Java 代理开始才能使用 InstrumentationLoadTimeWeaver。请参阅 Spring 文档。
一切都很好。唯一的问题是我们已经有了 Spring Insturment Java 代理
-javaagent:${CATALINA_HOME}/lib/spring-instrument-5.1.5.RELEASE.jar
就像我上面说的,这是我们只是更新版本的所有工作代码。
我确信 LTW 正在加载,因为我们可以看到 InstrumentationLoadTimeWeaver 类产生的错误。
@Override
public void addTransformer(ClassFileTransformer transformer) {
Assert.notNull(transformer, "Transformer must not be null");
FilteringClassFileTransformer actualTransformer =
new FilteringClassFileTransformer(transformer, this.classLoader);
synchronized (this.transformers) {
Assert.state(this.instrumentation != null,
"Must start with Java agent to use InstrumentationLoadTimeWeaver. See Spring documentation.");
this.instrumentation.addTransformer(actualTransformer);
this.transformers.add(actualTransformer);
}
}
我只是不知道如何使用空检测来实例化它。显然我错过了一些东西。可能是一些小而愚蠢的事情。但现在我没有想法。
跃然一笑
撒科打诨
随时随地看视频慕课网APP
相关分类