GAE,升级datanucleus jar包后的一些例外

时间:2012-04-04 06:18:35

标签: java google-app-engine datanucleus

当我将sdk orm jar更改为v2(默认包括sdk)时,我得到了一些例外信息。它是关于datanucleus-core-3.0.6.jar已经注册了bla bla .... 搜索之后,我知道这是3.0.6中的一个错误。所以,我通过datanucleus-core-3.0.10.jar重新划分它。 但是在编译pojo Enhancer时它没有成功

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.NoSuchMethodError: org.datanucleus.plugin.PluginManager.<init>(Lorg/datanucleus/PersistenceConfiguration;Lorg/datanucleus/ClassLoaderResolver;)V
    at org.datanucleus.OMFContext.<init>(OMFContext.java:159)
    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

这是我在\ lib \ user \ orm

中的jar文件
asm-3.3.1.jar
datanucleus-api-jdo-3.0.5.jar
datanucleus-api-jpa-3.0.6.jar
datanucleus-appengine-2.0.0-final.jar
datanucleus-core-3.0.10.jar
geronimo-jpa_2.0_spec-1.0.jar
jdo-api-3.0.jar
transaction-api-1.1.jar

我一直在寻找。有没有人知道它有什么问题?

2 个答案:

答案 0 :(得分:0)

你在CLASSPATH的某个地方有旧版本的datanucleus-core和datanucleus-enhancer。来自该堆栈跟踪的“OMFContext”在DataNucleus中已经存在了很长时间。

答案 1 :(得分:0)

我想我知道,为什么用新的datanucleus升级appengine是行不通的。它不是类路径条目!我发现在触发增强步骤的ant-macro.xml中,有一个指向appengine-tools-api.jar的链接,并且有一个类EnhancerTask。这可能是旧版本的链接,因为新的datanucleus-enhancer-3.0.1.jar拥有自己的EnhancerTask类。因此,使用新版本的datanucleus与旧的appengine sdk(与http://code.google.com/p/datanucleus-appengine/wiki/HowToUpdateTheSDKWithANewPluginVersion相反)的唯一方法是通过ant(https://developers.google.com)执行增强步骤/web-toolkit/doc/1.6/tutorial/appengine)或者可能是eclipse-datanucleus-plugin。不幸的是,这个插件在我的Eclipse中无法正常工作。安装/配置插件后,仍然没有项目上下文菜单“datanucleus”,我应该添加支持。所以我会尝试ant版本。