升级到1.7.0.RELEASE后出现NoClassDefFoundError [英] NoClassDefFoundError after upgrading to 1.7.0.RELEASE
问题描述
我试图在我的playframework项目中将应用程序从1.6.2.RELEASE升级到1.7.0.RELEASE. 插入查询工作正常,但是当spring-data尝试在获取针对查询的结果之后尝试使用类名对对象进行膨胀时,似乎会出现问题,如果针对查询没有结果,则它会返回一个空的arraylist而不会引发错误.
I was trying to upgrade my application from 1.6.2.RELEASE to 1.7.0.RELEASE in my playframework project. Insert queries are working fine but there seems to be an issue when spring-data tries to inflate the object using class name after fetching result against query, if there's no result against query then it returns an empty arraylist without throwing error.
1.7.0.RELEASE在另一个基于spring-integration框架的项目中运行良好.
1.7.0.RELEASE works fine in another project based on spring-integration framework.
下面是statck跟踪:-
below is statck trace :-
java.lang.NoClassDefFoundError: models/db/nosql/ACME
models.db.nosql.ACME_Instantiator_gtblf6.newInstance(Unknown Source)
org.springframework.data.convert.BytecodeGeneratingEntityInstantiator$EntityInstantiatorAdapter.createInstance(BytecodeGeneratingEntityInstantiator.java:193)
org.springframework.data.convert.BytecodeGeneratingEntityInstantiator.createInstance(BytecodeGeneratingEntityInstantiator.java:76)
org.springframework.data.mongodb.core.convert.MappingMongoConverter.read(MappingMongoConverter.java:250)
org.springframework.data.mongodb.core.convert.MappingMongoConverter.read(MappingMongoConverter.java:231)
org.springframework.data.mongodb.core.convert.MappingMongoConverter.read(MappingMongoConverter.java:191)
org.springframework.data.mongodb.core.convert.MappingMongoConverter.read(MappingMongoConverter.java:187)
org.springframework.data.mongodb.core.convert.MappingMongoConverter.read(MappingMongoConverter.java:78)
org.springframework.data.mongodb.core.MongoTemplate$ReadDbObjectCallback.doWith(MongoTemplate.java:2191)
org.springframework.data.mongodb.core.MongoTemplate.executeFindMultiInternal(MongoTemplate.java:1873)
org.springframework.data.mongodb.core.MongoTemplate.doFind(MongoTemplate.java:1696)
org.springframework.data.mongodb.core.MongoTemplate.doFind(MongoTemplate.java:1679)
org.springframework.data.mongodb.core.MongoTemplate.find(MongoTemplate.java:598)
org.springframework.data.mongodb.core.MongoTemplate.find(MongoTemplate.java:589)
GenerateACME.reverseBizCode(GenerateACME.java:42)
Global.onStart(Global.java:23)
play.core.j.JavaGlobalSettingsAdapter.onStart(JavaGlobalSettingsAdapter.scala:22)
play.api.GlobalPlugin.onStart(GlobalSettings.scala:220)
play.api.Play$$anonfun$start$1$$anonfun$apply$mcV$sp$1.apply(Play.scala:91)
play.api.Play$$anonfun$start$1$$anonfun$apply$mcV$sp$1.apply(Play.scala:91)
scala.collection.immutable.List.foreach(List.scala:383)
play.api.Play$$anonfun$start$1.apply$mcV$sp(Play.scala:91)
play.api.Play$$anonfun$start$1.apply(Play.scala:91)
play.api.Play$$anonfun$start$1.apply(Play.scala:91)
play.utils.Threads$.withContextClassLoader(Threads.scala:21)
play.api.Play$.start(Play.scala:90)
play.core.ReloadableApplication$$anonfun$get$1$$anonfun$apply$1$$anonfun$1.apply(ApplicationProvider.scala:157)
play.core.ReloadableApplication$$anonfun$get$1$$anonfun$apply$1$$anonfun$1.apply(ApplicationProvider.scala:130)
scala.Option.map(Option.scala:145)
play.core.ReloadableApplication$$anonfun$get$1$$anonfun$apply$1.apply(ApplicationProvider.scala:130)
play.core.ReloadableApplication$$anonfun$get$1$$anonfun$apply$1.apply(ApplicationProvider.scala:128)
scala.util.Success.flatMap(Try.scala:230)
play.core.ReloadableApplication$$anonfun$get$1.apply(ApplicationProvider.scala:128)
play.core.ReloadableApplication$$anonfun$get$1.apply(ApplicationProvider.scala:120)
scala.concurrent.impl.Future$PromiseCompletingRunnable.liftedTree1$1(Future.scala:24)
scala.concurrent.impl.Future$PromiseCompletingRunnable.run(Future.scala:24)
scala.concurrent.forkjoin.ForkJoinTask$AdaptedRunnableAction.exec(ForkJoinTask.java:1361)
scala.concurrent.forkjoin.ForkJoinTask.doExec(ForkJoinTask.java:260)
scala.concurrent.forkjoin.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1339)
scala.concurrent.forkjoin.ForkJoinPool.runWorker(ForkJoinPool.java:1979)
scala.concurrent.forkjoin.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:107)
推荐答案
我也遇到了此错误.我认为这是spring数据mongodb的错误.
I'm facing this error too. I think it's the bug of the spring data mongodb.
如果Db模型和所有服务,存储库都在一个项目中,则不会出现此类错误. 但是如果服务在另一个项目中,则可以100%复制.我找不到避免这种错误的方法.
If the Db model and all the service, repository are in one project, no such error. But if the service in another project, it can be reproduced 100%. I don't find a way to avoid this error.
现在,我正在尝试在mongodb持久层上使用OGM.
Now, I'm trying to use the OGM on the mongodb persistent layer.
这篇关于升级到1.7.0.RELEASE后出现NoClassDefFoundError的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!