如何使用AspectJ和Tomcat配置加载时编织?

时间:2012-04-05 16:09:04

标签: java tomcat aspectj load-time-weaving perf4j

我尝试以下一种方式配置加载时编织(使用Perf4J进行分析):

1)我将aop.xml添加到META-INF文件夹。部署时,META-INF放置在工件根目录中(即MyAppDeployed/META-INF)。

2)我将aspectjrt-1.6.1.jaraspectjweaver-1.6.1.jarcommons-jexl-1.1.jarcommons-logging.jar放入Tomcat/lib文件夹(起初我尝试了MyAppDeployed/WEB-INF/libs但是它也没用。)

3)我在启动Tomcat时向VM选项添加了-javaagent:C:\apache-tomcat-6.0.33\lib\aspectjweaver-1.6.1.jar

4)我的aop.xml

<!DOCTYPE aspectj PUBLIC "-//AspectJ//DTD//EN" "http://www.eclipse.org/aspectj/dtd/aspectj.dtd">

<aspectj>

    <aspects>
        <aspect name="org.perf4j.log4j.aop.TimingAspect"/>
    </aspects>

    <weaver options="-verbose -showWeaveInfo">           
        <include within="com.mypackages.MyClass"/>
    </weaver>
</aspectj>

我没有看到任何迹象表明装载时编织发生。无论是错误报告还是必要结果。我唯一的错误信息是:

Error occurred during initialization of VM
agent library failed to init: instrument
Error opening zip file: C:\apache-tomcat-6.0.33\lib\wrong-jar.jar

在指定javaagent参数时我在aspectjweaver-1.6.1.jar名称中出错的情况。如果写得正确 - 不会打印错误信息。

任何想法,我做错了什么?

P.S。我使用Java 5,并且我使用了1.5.4版本的aspectj尝试了完全相同的结果。

2 个答案:

答案 0 :(得分:4)

如果您想使用加载时间编织,您可以像往常一样使用 javac 编译类,然后使用(i)ajc 编译您的方面。您可以使用下面的蚂蚁任务

执行此操作
<target name="compile-aspect">
    <iajc source="1.6" target="1.6" showweaveinfo="true" verbose="true" outxml="true" debug="true" outjar="${dist.dir}/myaspect.jar">
            <argfiles>
                    <pathelement location="${src.dir}/sources.lst"/>
            </argfiles>
            <classpath>
                    <path refid="master-classpath" />
            </classpath>
    </iajc>
</target>

在编译期间,在类路径(&#34; master-classpath&#34; )中使用 aspectjrt.jar 就足够了。

由于 $ {src.dir} 中的所有Java类,我向iajc提供了一个源列表。在源列表中只有一行。

sources.lst

com/xx/yy/zz/LoggingAspect.java

我设置了一些iajc任务的属性,如下所示

outxml="true"
outjar="jar_file_name"

当我运行compile-aspect任务时,我有一个jar jar_file_name.jar 文件包含

META-INF/MANIFEST.MF
com/xx/yy/zz/LoggingAspect.class
META-INF/aop-ajc.xml

最后将* jar_file_name.jar *添加到您的Web应用程序的 WEB-INF / lib 文件夹中。

然后像以前一样用 -javaagents:/path_to_aspectjweaver.jar 启动Tomcat。

当我将aop.xml(或aop-ajc.xml)直接放在war文件下的META-INF中时,它不起作用。这种方式(我的意思是分离方面类进入罐子里)对我来说很好。

希望这有帮助。

答案 1 :(得分:4)

我试图在Tomcat中解决同样的问题。除了-javaagent选项之外,还需要确保aop.xml必须位于WEB-INF / classes / META-INF目录下。这对我来说有所不同。