Ошибка при использовании perf4j с аспектом (NoSuchMethodError)

Я пытаюсь использовать CTW с аспектом для профилирования моего приложения (cumulusrdf) с помощью perf4j.

Я могу скомпилировать все с помощью maven. Вывод консоли содержит запись для метода, который я использую для работы профилирования:

[INFO] --- aspectj-maven-plugin:1.5:compile (default-cli) @ cumulusrdf ---
[INFO] Join point 'method-execution(void edu.kit.aifb.cumulus.store.AbstractCassandraRdfHector.bulkLoad(java.io.File, java.lang.String, int))' in Type 'edu.kit.aifb.cumulus.store.AbstractCassandraRdfHector' (AbstractCassandraRdfHector.java:373) advised by around advice from 'org.perf4j.log4j.aop.TimingAspect' (perf4j-0.9.16-log4jonly.jar!AbstractTimingAspect.class(from AbstractTimingAspect.java))

Я использую цели aspectj:compile package для построения. Когда я пытаюсь запустить сгенерированную одну банку, я получаю следующее исключение:

java.lang.reflect.InvocationTargetException
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:606)
        at edu.kit.aifb.cumulus.cli.Main.main(Main.java:40)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:606)
        at com.simontuffs.onejar.Boot.run(Boot.java:340)
        at com.simontuffs.onejar.Boot.main(Boot.java:166)
Caused by: java.lang.NoSuchMethodError: org.perf4j.log4j.aop.TimingAspect.aspectOf()Lorg/perf4j/log4j/aop/TimingAspect;
        at edu.kit.aifb.cumulus.store.AbstractCassandraRdfHector.bulkLoad(AbstractCassandraRdfHector.java:373)
        at edu.kit.aifb.cumulus.cli.Load.main(Load.java:161)
        ... 11 more

Я не использую никаких параметров, кроме тех, что для моего приложения.

В моем pom.xml у меня есть следующие связанные разделы:

Определение плагина aspectj:

<plugins>
    <plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>aspectj-maven-plugin</artifactId>
        <version>1.5</version>

        <configuration>
            <aspectLibraries>
                <aspectLibrary>
                    <groupId>org.perf4j</groupId>
                    <artifactId>perf4j</artifactId>
                    <classifier>log4jonly</classifier>
                </aspectLibrary>
            </aspectLibraries>
            <source>1.6</source>
            <target>1.6</target>
            <complianceLevel>1.6</complianceLevel>
            <verbose>true</verbose>
            <showWeaveInfo>true</showWeaveInfo>
            <weaveMainSourceFolder>true</weaveMainSourceFolder>
        </configuration>

        <!--<executions>
            <execution>
                <goals>
                    <goal>compile</goal>       <! use this goal to weave all your main classes >
                </goals>
                <configuration>
                    <showWeaveInfo>true</showWeaveInfo>
                </configuration>
            </execution>
        </executions>-->
    </plugin>

    <!-- ... -->
</plugins>

Зависимости связанных артефактов:

<dependencies>
    <dependency>
        <groupId>org.perf4j</groupId>
        <artifactId>perf4j</artifactId>
        <version>0.9.16</version>
        <classifier>log4jonly</classifier>
    </dependency>
    <dependency>
        <groupId>org.perf4j</groupId>
        <artifactId>perf4j</artifactId>
        <version>0.9.16</version>
    </dependency>
    <dependency>
        <groupId>org.aspectj</groupId>
        <artifactId>aspectjweaver</artifactId>
        <version>1.7.3</version>
    </dependency>
    <dependency>
        <groupId>org.aspectj</groupId>
        <artifactId>aspectjrt</artifactId>
        <version>1.7.3</version>
    </dependency>
    <dependency>
        <groupId>commons-jexl</groupId>
        <artifactId>commons-jexl</artifactId>
        <version>1.1</version>
    </dependency>

    <!-- ... -->
</dependencies>

Определение плагина с одной банкой:

<plugins>
    <plugin>
        <groupId>org.dstovall</groupId>
        <artifactId>onejar-maven-plugin</artifactId>
        <version>1.4.4</version>
        <executions>
            <execution>
                <configuration>
                    <mainClass>edu.kit.aifb.cumulus.cli.Main</mainClass>
                    <onejarVersion>0.97</onejarVersion>
                    <attachToBuild>true</attachToBuild>
                    <classifier>onejar</classifier>
                </configuration>
                <goals>
                    <goal>one-jar</goal>
                </goals>
            </execution>
        </executions>
    </plugin>

    <!-- ... -->
</plugins>

Кто-нибудь знает, что я делаю неправильно?


person Sibbo    schedule 04.02.2014    source источник


Ответы (1)


Пытаться

<plugin>
    <groupId>org.codehaus.mojo</groupId>
    <artifactId>aspectj-maven-plugin</artifactId>
    <version>1.4</version>
    <configuration>
        <source>1.6</source>
        <target>1.6</target>
        <complianceLevel>1.6</complianceLevel>
        <verbose>true</verbose>
        <showWeaveInfo>true</showWeaveInfo>
        <weaveMainSourceFolder>true</weaveMainSourceFolder>                    

        <weaveDependencies>
            <dependency>
                <groupId>org.perf4j</groupId>
                <artifactId>perf4j</artifactId>
                <classifier>log4jonly</classifier>
            </dependency>
        </weaveDependencies>

    </configuration>
    <executions>
        <execution>
            <id>aspectj-compile</id>
            <goals>
                <goal>compile</goal>
                <goal>test-compile</goal>
            </goals>
        </execution>
    </executions>
</plugin>
person buom    schedule 04.03.2014
comment
Некоторые могут спросить, как это работает, но он просто помещает отсутствующие классы в org\perf4j\log4j\aop\ в вашей банке, так вот как классы находятся. - person Rafał; 05.08.2014