猿问

必须启动 InstrumentationLoadTimeWeaver / openjdk 11

我们有一个生产 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);

    }

}

我只是不知道如何使用空检测来实例化它。显然我错过了一些东西。可能是一些小而愚蠢的事情。但现在我没有想法。


跃然一笑
浏览 180回答 1
1回答

撒科打诨

似乎问题出在类加载上添加 '-verbose:class' 选项以查看是否InstrumentationLoadTimeWeaver已加载尝试将此选项添加到您的Tomcat上下文配置中&nbsp;<Context> ... <Loader delegate="true"/> ... </Context>Tomcat 7.0.27 中的一些更改可能会触发此问题使 Catalina.getParentClassLoader 的实现与代码库中的类似方法保持一致,如果没有设置父类加载器,则让它返回系统类加载器。(市场)
随时随地看视频慕课网APP

相关分类

Java
我要回答