java - 如何使用 AspectJ 和 Tomcat 配置加载时织入?

标签 java tomcat aspectj load-time-weaving perf4j

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

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

2) 我把 aspectjrt-1.6.1.jar, aspectjweaver-1.6.1.jar, commons-jexl-1.1.jar >, commons-logging.jarTomcat/lib 文件夹(起初我尝试了 MyAppDeployed/WEB-INF/libs 但它也没有没用)。

3) 我在启动 Tomcat 时将 -javaagent:C:\apache-tomcat-6.0.33\lib\aspectjweaver-1.6.1.jar 添加到 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

如果我在指定 javaagent 参数时在 aspectjweaver-1.6.1.jar 名称中犯了错误。如果它写得正确 - 不会打印错误消息。

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

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

最佳答案

如果你想使用加载时编织,你可以先像往常一样用 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。在源列表中只有一行。

sources.lst

com/xx/yy/zz/LoggingAspect.java

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

outxml="true"
outjar="jar_file_name"

当我运行编译方面的任务时,我有一个 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。

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

希望这对您有所帮助。

关于java - 如何使用 AspectJ 和 Tomcat 配置加载时织入?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10032092/

相关文章:

java - 在 Java 中创建 Vector 类对象

java - DynamoDB 对象集嵌套查询

java - 如何将我的第一个程序提交到SPOJ平台?为什么我收到超出时间限制或运行时错误 NZEC?

tomcat - Tomcat 未正确处理发送文件的 Jersey Rest API 调用

java - 编译时自动添加未实现的方法

java - UUID.randomUUID().getLeastSignificantBits() 总是返回负值?

maven - 从maven项目中获取jar

Tomcat 7 管理器 - 命令被禁用

java - AspectJ 和 Maven 警告 : "Advice defined in ... has not been applied?"

java - 在 AspectJ 中获取泛型方法调用的返回类型