我使用的是Spring 3.2.9,Tomcat 6.0.44
当部署在 Tomcat 上时,我正在尝试配置应用程序的 Spring 检测提供程序(例如 spring-instrumentation.jar)以进行加载时编织。
我有一个不使用的要求:
在命令行中使用“-javaagent:/path/path/spring-instrument.jar”进行配置。
我读到,我可以通过修改应用程序 Tomcat 配置的 元素(在 Tomcat 的 server.xml 或我的 Web 应用程序的 context.xml 中)来配置 Spring 检测。将适当的 元素添加到 server.xml 会导致我的应用程序正确配置为与 Spring 的检测提供程序一起运行。将其添加到 context.xml(见下文)不会产生有效的设置。
我有一个 META-INF/aop.xml 文件,如下所示:
<aspectj>
<weaver options="-verbose -showWeaveInfo -debug">
<include within="com.mv.xx.services..*"/>
<exclude within="com.mv.xx.aop..*"/>
</weaver>
<aspects>
<aspect name="com.mv.xx.aop.MyAspect"/>
</aspects>
</aspectj>
我还指定要通过将其添加到我的 Spring 上下文配置来使用加载时编织:
<context:load-time-weaver />
我将此 jar 添加到我的应用程序的类路径中:
spring-instrument-tomcat.jar
我已经尝试过:
启动 Tomcat 时,如果我使用 -javaagent 参数在命令行上识别 spring-instrument.jar 的位置,如下所示:
-javaagent:/path/path2/spring-instrument-3.2.9.RELEASE.jar
一切正常。
接下来,我从命令行中删除了“-javaagent:/path/path2/spring-instrument-3.2.9.RELEASE.jar”。
在 Tomcat 的 server.xml 文件(位于 $CATALINE_HOME/conf 中)中,我向 元素添加了一个 元素,如下所示:
<Context path="/myApp" docBase="myApp">
<Loader loaderClass="org.springframework.instrument.classloading.tomcat.TomcatInstrumentableClassLoader"/>
</Context>
通过此配置,一切正常。但是,我要求不要修改 Tomcat 的 server.xml,因为我无法控制 server.xml(DevOps 可以控制,并且不愿意修改它)。
接下来,我从 Tomcat 的 server.xml 中删除了 元素。
根据春季文档,我可以将 /META-INF/context.xml 添加到我的 webapp 中,并将以前位于 Tomcat 的 server.xml 中的 元素放入 context.xml 中,如下所示:
<Context>
<Context path="/myApp" docBase="myApp">
<Loader loaderClass="org.springframework.instrument.classloading.tomcat.TomcatInstrumentableClassLoader"/>
</Context>
</Context>
但是,当我重新启动 Tomcat 时,我在日志中收到一条错误消息:
SEVERE: Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListener
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.context.weaving.AspectJWeavingEnabler#0': Initialization of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'loadTimeWeaver': Initialization of bean failed; nested exception is java.lang.IllegalStateException: ClassLoader [org.apache.catalina.loader.WebappClassLoader] does NOT provide an 'addTransformer(ClassFileTransformer)' method. Specify a custom LoadTimeWeaver or start your Java virtual machine with Spring's agent: -javaagent:org.springframework.instrument.jar
经过一番研究后,我读到了一些建议我修改<context:load-time-weaver/>
我的 Spring 配置中的元素,如下所示:
<context:load-time-weaver weaver-class="org.springframework.instrument.classloading.InstrumentationLoadTimeWeaver" />
并将包含 InstrumentationLoadTimeWeaver.class 的 jar 添加到我的类路径中。
但是,当我这样做时,我在日志中收到以下错误消息:
SEVERE: Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListener
java.lang.IllegalStateException: Must start with Java agent to use InstrumentationLoadTimeWeaver. See Spring documentation.
etc....
谁能解释如何使用 Spring 和 Tomcat 设置加载时编织,而无需在命令行上使用 -javaagent,并且无需修改 server.xml?