JDO3.0增强了GAE 1.7.2中的失败

时间:2012-09-27 06:59:44

标签: java google-app-engine datanucleus

我使用ant来构建我的GAE WebApp。这是数据核目标:

<target name="datanucleusenhance" depends="compile"
    description="Performs enhancement on compiled data classes.">
    <enhance_war war="war">
    </enhance_war>
</target>

这是我得到的错误:

org.datanucleus.exceptions.NucleusException:插件(Bundle)“org.datanucleus”已经注册。确保类路径中没有相同插件的多个JAR版本。网址 “文件:/home/xxxx/.eclipse/org.eclipse.platform_4.2.0_1473617060/plugins/com.google.appengine.eclipse.sdkbundle_1.7.2/appengine-java-sdk-1.7.2/lib/opt/tools/ datanucleus / v1 / datanucleus-core-1.1.5.jar“已经注册,您正在尝试注册位于URL的相同插件”文件:/war/WEB-INF/lib/datanucleus-core-3.1.0- m5.jar“。

我尝试过这个蚂蚁目标:

<target name="datanucleusenhance" depends="compile" description="Performs enhancement on compiled data classes.">
    <enhance_war war="war">
        <args>
            <arg value="-enhancerVersion" />
            <arg value="v3.1.0" />
        </args>
    </enhance_war>
</target>

我试图删除“datanucleus-core-1.1.5.jar”。那么错误是:

java.lang.RuntimeException: Unexpected exception
    at com.google.appengine.tools.enhancer.Enhancer.execute(Enhancer.java:76)
    at com.google.appengine.tools.enhancer.Enhance.<init>(Enhance.java:71)
    at com.google.appengine.tools.enhancer.Enhance.main(Enhance.java:51)
Caused by: java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at com.google.appengine.tools.enhancer.Enhancer.execute(Enhancer.java:74)
    ... 2 more
Caused by: java.lang.NoClassDefFoundError: org/datanucleus/OMFContext
    at org.datanucleus.enhancer.DataNucleusEnhancer.<init>(DataNucleusEnhancer.java:172)
    at org.datanucleus.enhancer.DataNucleusEnhancer.<init>(DataNucleusEnhancer.java:150)
    at org.datanucleus.enhancer.DataNucleusEnhancer.main(DataNucleusEnhancer.java:1157)
    ... 7 more
Caused by: java.lang.ClassNotFoundException: org.datanucleus.OMFContext
    at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
    at com.google.appengine.tools.enhancer.EnhancerLoader.loadClass(EnhancerLoader.java:107)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
    ... 10 more

如何将JDO3.0与GAE1.7.2一起使用?

3 个答案:

答案 0 :(得分:5)

使用Intellij的GAE插件,我不得不删除默认配置的orm目录,并专门添加更高版本的库。

GAE SDK的组织如下:

/lib/user/orm (default persistence libraries I removed)

AND

/lib/opt/user/datanucleus/v2

要在IntelliJ中访问此配置,请从我的项目的上下文菜单中访问:

{context menu} -> Open Module Settings -> Libraries -> AppEngine ORM 
  • 使用[-]按钮删除此目录中的jar:/lib/user/orm
  • 使用[+]按钮在此目录中添加jar:/lib/opt/user/datanucleus/v2

答案 1 :(得分:1)

得到了答案。正确的蚂蚁目标应该是:

<target name="datanucleusenhance" depends="compile" description="Performs enhancement on compiled data classes.">
    <enhance_war war="war">
        <args>
            <arg value="-enhancerVersion" />
            <arg value="v2" />
        </args>
    </enhance_war>
</target>

版本是GAE JDO / JPA插件版本。(感谢DataNucleus!:)

答案 2 :(得分:0)

您似乎在混淆使用哪个版本的从属jar。 GAE 1.7.2使用GAE JDO / JPA插件v2.x,后者又需要DataNucleus 3.x.你显然有(各种)DataNucleus 1.x罐子存在。