8

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

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

2)我把aspectjrt-1.6.1.jar, aspectjweaver-1.6.1.jar, commons-jexl-1.1.jar,commons-logging.jar放到Tomcat/lib文件夹中(起初我尝试过MyAppDeployed/WEB-INF/libs,但也没有用)。

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

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

以防我aspectjweaver-1.6.1.jar在指定 javaagent 参数时名称错误。如果正确写入 - 不会打印错误消息。

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

PS我使用Java 5,我用1.5.4aspectj的版本尝试了同样的事情,结果完全相同。

4

2 回答 2

5

如果你想使用加载时间编织,你可以像往常一样首先用javac编译你的类,然后用(i)ajc编译你的方面。您可以使用如下所示的 ant 任务执行此操作

<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>

在编译期间在类路径(“master-classpath” )中有aspectjrt.jar就足够了。

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

来源.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中时,它不起作用。这种方式(我的意思是将方面类分离到一个 jar 中)对我来说很好。

希望这可以帮助。

于 2012-09-30T22:39:36.050 回答
4

我试图在Tomcat中解决同样的问题。除了 -javaagent 选项,您需要确保 aop.xml 必须在 WEB-INF/classes/META-INF 目录下。这对我来说很重要。

于 2014-11-12T23:15:42.190 回答