0

私の質問はとても簡単です。次の POM が与えられます。

<build>
    <plugins>
        <plugin>
            <groupId>org.datanucleus</groupId>
            <artifactId>maven-datanucleus-plugin</artifactId>
            <version>3.0.0-release</version>
            <configuration>
                <log4jConfiguration>${basedir}/src/main/resources/log4j.properties</log4jConfiguration>
                <verbose>true</verbose>
                <props>${basedir}/src/main/resources/datanucleus.properties</props>
            </configuration>
            <executions>
                <execution>
                    <phase>compile</phase>
                    <goals>
                        <goal>enhance</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>
<repositories>
    <repository>
        <id>DataNucleus_Repos2</id>
        <name>DataNucleus Repository</name>
        <url>http://www.datanucleus.org/downloads/maven2</url>
    </repository>
    <repository> <!-- Required for transaction-api transitive dep -->
        <id>Java_Net_LEGACY</id>
        <name>Java.Net legacy</name>
        <url>http://download.java.net/maven/1/</url>
        <layout>legacy</layout>
    </repository>
</repositories>
<pluginRepositories>
    <pluginRepository>
        <id>DataNucleus_2</id>
        <url>http://www.datanucleus.org/downloads/maven2/</url>
    </pluginRepository>
</pluginRepositories>

<dependencies>
    <dependency>
        <groupId>org.datanucleus</groupId>
        <artifactId>datanucleus-core</artifactId>
        <scope>runtime</scope>
        <version>3.0.2</version>
    </dependency>
    <dependency>
        <groupId>org.datanucleus</groupId>
        <artifactId>datanucleus-api-jdo</artifactId>
        <version>3.0.2</version>
    </dependency>        
    <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.16</version>
        </dependency>
    <dependency>
        <groupId>org.datanucleus</groupId>
        <artifactId>datanucleus-rdbms</artifactId>
        <version>3.0.2</version>
    </dependency>
    <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.9</version>
        </dependency>
    <dependency>
        <groupId>javax.jdo</groupId>
        <artifactId>jdo-api</artifactId>
        <version>3.0</version>
    </dependency>
    <dependency>
        <groupId>org.apache.geronimo.specs</groupId>
        <artifactId>geronimo-jpa_2.0_spec</artifactId>
        <version>1.0</version>
    </dependency>
    <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.18</version>
        </dependency>
</dependencies>

そして、ファイル log4j.properties と datanucleus.properties が予想される場所にあることを考えると、実行すると

mvn compile

I get (datanucleus.log ファイルから取得)

19:36:11,297 (メイン) エラー [DataNucleus.Enhancer] - DataNucleus Enhancer がエラーで完了しました。詳細については、エンハンサー ログを確認してください。一部のクラスは拡張されている可能性がありますが、エラーが発生しましたAPI "JDO" の MetaDataManager の作成中にエラーが発生しました: org.datanucleus.exceptions.NucleusException: API "JDO" の MetaDataManager の作成中にエラーが発生しました: org.datanucleus.NucleusContext.getMetaDataManager(NucleusContext.java で) :964) org.datanucleus.enhancer.DataNucleusEnhancer.getMetaDataManager(DataNucleusEnhancer.java:261) org.datanucleus.enhancer.DataNucleusEnhancer.getFileMetadataForInput(DataNucleusEnhancer.java:716) org.datanucleus.enhancer.DataNucleusEnhancer.enhance(DataNucleusEnhancer. java:590) org.datanucleus.enhancer.DataNucleusEnhancer.main (DataNucleusEnhancer.java:1390) で

原因: java.lang.reflect.InvocationTargetException at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) at java.lang org.datanucleus.plugin.NonManagedPluginRegistry.createExecutableExtension(NonManagedPluginRegistry.java:681) の .reflect.Constructor.newInstance (不明なソース) .getMetaDataManager(NucleusContext.java:958) ... 4 つ以上

原因: java.lang.NoSuchFieldError: supportsORM at org.datanucleus.api.jdo.metadata.JDOMetaDataManager.(JDOMetaDataManager.java:142) ... 11 詳細

ログを有効にして、アプリケーションで実行されているクエリを確認したいと考えています。注意すべきことは、POM から log4j の依存関係を削除すると、機能強化が正常に機能することです。もちろん、ログ ファイルは更新されなくなりましたが、クラスは拡張されています。

上記の動作に関連するアイデアは大歓迎です。

4

1 に答える 1

0

ドキュメントには、特に実行におけるプラグインの構成の異なる外観が示されています。

<executions>
  <execution>
    <phase>process-classes</phase>
    <goals>
      <goal>enhance</goal>
    </goals>
  </execution>
</executions>

多くの問題があるかもしれません。さらに、pomからリポジトリ定義を削除する必要があります。これは、短いチェックに基づいて、これらすべての依存関係がMavenCentralを介して利用できるためです。本当にリポジトリを設定する必要がある場合は、代わりにリポジトリマネージャを使用する必要があります。

于 2012-04-30T16:53:07.603 に答える