如何基于Maven启用Datanucleus应用程序的日志记录?

时间:2012-04-30 16:44:37

标签: maven jdo datanucleus

我的问题很简单。 鉴于以下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

我得到(取自datanucleus.log文件)

  

19:36:11,297(主要)ERROR [DataNucleus.Enhancer] - DataNucleus   Enhancer完成时出错。请查看增强器日志   全部细节。有些课程可能已经增强但有些课程有所增加   错误为API“JDO”创建MetaDataManager时出错:   org.datanucleus.exceptions.NucleusException:创建错误   MetaDataManager for API“JDO”:at   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(本机方法)     at sun.reflect.NativeConstructorAccessorImpl.newInstance(未知   来源)at   sun.reflect.DelegatingConstructorAccessorImpl.newInstance(未知   来自java.lang.reflect.Constructor.newInstance(未知来源)     在   org.datanucleus.plugin.NonManagedPluginRegistry.createExecutableExtension(NonManagedPluginRegistry.java:681)     在   org.datanucleus.plugin.PluginManager.createExecutableExtension(PluginManager.java:314)     在   org.datanucleus.NucleusContext.getMetaDataManager(NucleusContext.java:958)     ......还有4个

     

引起:java.lang.NoSuchFieldError:supportsORM at   org.datanucleus.api.jdo.metadata.JDOMetaDataManager。(JDOMetaDataManager.java:142)     ......还有11个

我想启用日志记录以查看我的应用程序正在执行哪些查询。 需要注意的是,从POM中删除log4j依赖项时,增强功能正常。当然,日志文件不再更新,但类增强了。

任何与上述行为相关的想法都将不胜感激。

1 个答案:

答案 0 :(得分:0)

该文档给出了插件配置的不同外观,特别是在执行中:

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

这可能有很多问题。此外,您应该从pom中删除存储库定义,因为基于简短的检查,所有这些依赖关系都可以通过maven central获得。如果您确实需要配置存储库,则应使用存储库管理器。